depmod: Introduce outdir option

This option is equivalent to basedir, with the small difference being
that's where the meta-data files are generated. In other words, this
allows us to have read-only input modules and modules.dep, while still
being able to generate the meta-data files.

Signed-off-by: Emil Velikov <emil.velikov@collabora.com>
[ Move files to a different dir so input files (produced by kernel build
  system is separate from the files generated by depmod (output) ]
Signed-off-by: Lucas De Marchi <lucas.demarchi@gmail.com>
This commit is contained in:
Emil Velikov 2023-02-06 13:18:34 +00:00 committed by Lucas De Marchi
parent 06fadcc6b1
commit 1712a1548e
8 changed files with 128 additions and 3 deletions

View File

@ -45,6 +45,7 @@
<cmdsynopsis>
<command>depmod</command>
<arg><option>-b <replaceable>basedir</replaceable></option></arg>
<arg><option>-o <replaceable>outdir</replaceable></option></arg>
<arg><option>-e</option></arg>
<arg><option>-E <replaceable>Module.symvers</replaceable></option></arg>
<arg><option>-F <replaceable>System.map</replaceable></option></arg>
@ -151,6 +152,25 @@
</para>
</listitem>
</varlistentry>
<varlistentry>
<term>
<option>-o <replaceable>outdir</replaceable></option>
</term>
<term>
<option>--outdir <replaceable>outdir</replaceable></option>
</term>
<listitem>
<para>
Set the output directory where depmod will store any generated file.
<replaceable>outdir</replaceable> serves as a root to that location,
similar to how <replaceable>basedir</replaceable> is used. Also this
setting takes precedence and if used together with
<replaceable>basedir</replaceable> it will result in the input being
that directory, but the output being the one set by
<replaceable>outdir</replaceable>.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term>
<option>-C</option>

View File

@ -61,6 +61,9 @@ map=(
["test-depmod/modules-order-compressed/lib/modules/4.4.4/kernel/drivers/block/cciss.ko"]="mod-fake-cciss.ko"
["test-depmod/modules-order-compressed/lib/modules/4.4.4/kernel/drivers/scsi/hpsa.ko"]="mod-fake-hpsa.ko"
["test-depmod/modules-order-compressed/lib/modules/4.4.4/kernel/drivers/scsi/scsi_mod.ko"]="mod-fake-scsi-mod.ko"
["test-depmod/modules-outdir/lib/modules/4.4.4/kernel/drivers/block/cciss.ko"]="mod-fake-cciss.ko"
["test-depmod/modules-outdir/lib/modules/4.4.4/kernel/drivers/scsi/hpsa.ko"]="mod-fake-hpsa.ko"
["test-depmod/modules-outdir/lib/modules/4.4.4/kernel/drivers/scsi/scsi_mod.ko"]="mod-fake-scsi-mod.ko"
["test-modinfo/mod-simple-i386.ko"]="mod-simple-i386.ko"
["test-modinfo/mod-simple-x86_64.ko"]="mod-simple-x86_64.ko"
["test-modinfo/mod-simple-sparc64.ko"]="mod-simple-sparc64.ko"

View File

@ -0,0 +1,37 @@
# Aliases extracted from modules themselves.
alias pci:v0000103Cd00003230sv0000103Csd0000323Dbc*sc*i* cciss
alias pci:v0000103Cd00003230sv0000103Csd00003237bc*sc*i* cciss
alias pci:v0000103Cd00003238sv0000103Csd00003215bc*sc*i* cciss
alias pci:v0000103Cd00003238sv0000103Csd00003214bc*sc*i* cciss
alias pci:v0000103Cd00003238sv0000103Csd00003213bc*sc*i* cciss
alias pci:v0000103Cd00003238sv0000103Csd00003212bc*sc*i* cciss
alias pci:v0000103Cd00003238sv0000103Csd00003211bc*sc*i* cciss
alias pci:v0000103Cd00003230sv0000103Csd00003235bc*sc*i* cciss
alias pci:v0000103Cd00003230sv0000103Csd00003234bc*sc*i* cciss
alias pci:v0000103Cd00003230sv0000103Csd00003223bc*sc*i* cciss
alias pci:v0000103Cd00003220sv0000103Csd00003225bc*sc*i* cciss
alias pci:v00000E11d00000046sv00000E11sd0000409Dbc*sc*i* cciss
alias pci:v00000E11d00000046sv00000E11sd0000409Cbc*sc*i* cciss
alias pci:v00000E11d00000046sv00000E11sd0000409Bbc*sc*i* cciss
alias pci:v00000E11d00000046sv00000E11sd0000409Abc*sc*i* cciss
alias pci:v00000E11d00000046sv00000E11sd00004091bc*sc*i* cciss
alias pci:v00000E11d0000B178sv00000E11sd00004083bc*sc*i* cciss
alias pci:v00000E11d0000B178sv00000E11sd00004082bc*sc*i* cciss
alias pci:v00000E11d0000B178sv00000E11sd00004080bc*sc*i* cciss
alias pci:v00000E11d0000B060sv00000E11sd00004070bc*sc*i* cciss
alias pci:v0000103Cd*sv*sd*bc01sc04i* hpsa
alias pci:v0000103Cd0000323Bsv0000103Csd00003356bc*sc*i* hpsa
alias pci:v0000103Cd0000323Bsv0000103Csd00003355bc*sc*i* hpsa
alias pci:v0000103Cd0000323Bsv0000103Csd00003354bc*sc*i* hpsa
alias pci:v0000103Cd0000323Bsv0000103Csd00003353bc*sc*i* hpsa
alias pci:v0000103Cd0000323Bsv0000103Csd00003352bc*sc*i* hpsa
alias pci:v0000103Cd0000323Bsv0000103Csd00003351bc*sc*i* hpsa
alias pci:v0000103Cd0000323Bsv0000103Csd00003350bc*sc*i* hpsa
alias pci:v0000103Cd0000323Asv0000103Csd00003233bc*sc*i* hpsa
alias pci:v0000103Cd0000323Asv0000103Csd0000324Bbc*sc*i* hpsa
alias pci:v0000103Cd0000323Asv0000103Csd0000324Abc*sc*i* hpsa
alias pci:v0000103Cd0000323Asv0000103Csd00003249bc*sc*i* hpsa
alias pci:v0000103Cd0000323Asv0000103Csd00003247bc*sc*i* hpsa
alias pci:v0000103Cd0000323Asv0000103Csd00003245bc*sc*i* hpsa
alias pci:v0000103Cd0000323Asv0000103Csd00003243bc*sc*i* hpsa
alias pci:v0000103Cd0000323Asv0000103Csd00003241bc*sc*i* hpsa

View File

@ -0,0 +1,3 @@
kernel/drivers/block/cciss.ko:
kernel/drivers/scsi/scsi_mod.ko:
kernel/drivers/scsi/hpsa.ko: kernel/drivers/scsi/scsi_mod.ko

View File

@ -0,0 +1,7 @@
#336
kernel/drivers/block/cciss.ko
#2094
kernel/drivers/scsi/scsi_mod.ko
#2137
kernel/drivers/scsi/hpsa.ko

View File

@ -57,6 +57,42 @@ DEFINE_TEST(depmod_modules_order_for_compressed,
},
});
#define MODULES_OUTDIR_UNAME "4.4.4"
#define MODULES_OUTDIR_ROOTFS TESTSUITE_ROOTFS "test-depmod/modules-outdir"
#define MODULES_OUTDIR_LIB_MODULES_OUTPUT MODULES_OUTDIR_ROOTFS "/outdir/lib/modules/" MODULES_OUTDIR_UNAME
#define MODULES_OUTDIR_LIB_MODULES_INPUT MODULES_OUTDIR_ROOTFS "/lib/modules/" MODULES_OUTDIR_UNAME
static noreturn int depmod_modules_outdir(const struct test *t)
{
const char *progname = ABS_TOP_BUILDDIR "/tools/depmod";
const char *const args[] = {
progname,
"--outdir", MODULES_OUTDIR_ROOTFS "/outdir/",
NULL,
};
test_spawn_prog(progname, args);
exit(EXIT_FAILURE);
}
DEFINE_TEST(depmod_modules_outdir,
#if defined(KMOD_SYSCONFDIR_NOT_ETC)
.skip = true,
#endif
.description = "check if depmod honours the outdir option",
.config = {
[TC_UNAME_R] = MODULES_OUTDIR_UNAME,
[TC_ROOTFS] = MODULES_OUTDIR_ROOTFS,
},
.output = {
.files = (const struct keyval[]) {
{ MODULES_OUTDIR_LIB_MODULES_OUTPUT "/modules.dep",
MODULES_OUTDIR_ROOTFS "/correct-modules.dep" },
{ MODULES_OUTDIR_LIB_MODULES_OUTPUT "/modules.alias",
MODULES_OUTDIR_ROOTFS "/correct-modules.alias" },
{ }
},
});
#define SEARCH_ORDER_SIMPLE_ROOTFS TESTSUITE_ROOTFS "test-depmod/search-order-simple"
static noreturn int depmod_search_order_simple(const struct test *t)
{

View File

@ -58,11 +58,12 @@ static const char *default_cfg_paths[] = {
NULL
};
static const char cmdopts_s[] = "aAb:C:E:F:euqrvnP:wmVh";
static const char cmdopts_s[] = "aAb:o:C:E:F:euqrvnP:wmVh";
static const struct option cmdopts[] = {
{ "all", no_argument, 0, 'a' },
{ "quick", no_argument, 0, 'A' },
{ "basedir", required_argument, 0, 'b' },
{ "outdir", required_argument, 0, 'o' },
{ "config", required_argument, 0, 'C' },
{ "symvers", required_argument, 0, 'E' },
{ "filesyms", required_argument, 0, 'F' },
@ -104,6 +105,7 @@ static void help(void)
"\n"
"The following options are useful for people managing distributions:\n"
"\t-b, --basedir=DIR Use an image of a module tree.\n"
"\t-o, --outdir=DIR Output directory for generated files.\n"
"\t-F, --filesyms=FILE Use the file instead of the\n"
"\t current kernel symbols.\n"
"\t-E, --symvers=FILE Use Module.symvers file to check\n"
@ -467,6 +469,8 @@ struct cfg {
const char *kversion;
char dirname[PATH_MAX];
size_t dirnamelen;
char outdirname[PATH_MAX];
size_t outdirnamelen;
char sym_prefix;
uint8_t check_symvers;
uint8_t print_unknown;
@ -2576,7 +2580,7 @@ static int depmod_output(struct depmod *depmod, FILE *out)
{ "modules.devname", output_devname },
{ }
};
const char *dname = depmod->cfg->dirname;
const char *dname = depmod->cfg->outdirname;
int dfd, err = 0;
struct timeval tv;
@ -2585,6 +2589,11 @@ static int depmod_output(struct depmod *depmod, FILE *out)
if (out != NULL)
dfd = -1;
else {
err = mkdir_p(dname, strlen(dname), 0755);
if (err < 0) {
CRIT("could not create directory %s: %m\n", dname);
return err;
}
dfd = open(dname, O_RDONLY);
if (dfd < 0) {
err = -errno;
@ -2898,6 +2907,7 @@ static int do_depmod(int argc, char *argv[])
FILE *out = NULL;
int err = 0, all = 0, maybe_all = 0, n_config_paths = 0;
_cleanup_free_ char *root = NULL;
_cleanup_free_ char *out_root = NULL;
_cleanup_free_ const char **config_paths = NULL;
const char *system_map = NULL;
const char *module_symvers = NULL;
@ -2927,6 +2937,11 @@ static int do_depmod(int argc, char *argv[])
free(root);
root = path_make_absolute_cwd(optarg);
break;
case 'o':
if (out_root)
free(out_root);
out_root = path_make_absolute_cwd(optarg);
break;
case 'C': {
size_t bytes = sizeof(char *) * (n_config_paths + 2);
void *tmp = realloc(config_paths, bytes);
@ -3009,7 +3024,11 @@ static int do_depmod(int argc, char *argv[])
cfg.dirnamelen = snprintf(cfg.dirname, PATH_MAX,
"%s/lib/modules/%s",
root == NULL ? "" : root, cfg.kversion);
root ?: "", cfg.kversion);
cfg.outdirnamelen = snprintf(cfg.outdirname, PATH_MAX,
"%s/lib/modules/%s",
out_root ?: (root ?: ""), cfg.kversion);
if (optind == argc)
all = 1;