platform/upstream/kmod.git
10 years agobuild-sys: Remove bogus line causing warning
Lucas De Marchi [Thu, 20 Mar 2014 12:50:12 +0000 (09:50 -0300)]
build-sys: Remove bogus line causing warning

./configure: line 14316: xyes: command not found

We are not using have_manpages, so remove it.

10 years agoAdd test for depmod using search dirs with same prefix
Lucas De Marchi [Wed, 19 Mar 2014 12:15:59 +0000 (09:15 -0300)]
Add test for depmod using search dirs with same prefix

Test depmod with search dirs "foo" and "foobar". Previously to 49b33c1
("depmod: do not allow partial matches with "search" directive") we were
failing this test due to matching the prefix without checking if
it's the full dir name.

We are adding 2 tests here in order to catch the case we only pass the
test due to processing the directories in a favourable order.

10 years agodepmod: do not allow partial matches with "search" directive
Anssi Hannula [Tue, 18 Mar 2014 23:26:00 +0000 (01:26 +0200)]
depmod: do not allow partial matches with "search" directive

Currently e.g. "search foo foobar built-in" will cause unpredictable
results if baz.ko is in both foo/ and foobar/, since "foo" in search may
match both of those directories and the preferred module therefore
depends on processing order.

Fix the code to ensure that the match is performed on full pathname
components only.

10 years agoAdd test for simple search order in depmod
Lucas De Marchi [Wed, 19 Mar 2014 10:59:38 +0000 (07:59 -0300)]
Add test for simple search order in depmod

10 years agodepmod: fix debug print parameter order
Anssi Hannula [Tue, 18 Mar 2014 23:26:01 +0000 (01:26 +0200)]
depmod: fix debug print parameter order

10 years agolibkmod-elf: Fix check by class in get_modversions()
Lucas De Marchi [Fri, 7 Mar 2014 04:17:10 +0000 (01:17 -0300)]
libkmod-elf: Fix check by class in get_modversions()

Commit 51c409b ("Cache the offset of crc") unintentinally changed the
comparison "if (elf->class & KMOD_ELF_32)" to
"if (elf->class == KMOD_ELF_32)".

This has been reported by Serge Voilokov <serge0x76@gmail.com>:

On Raspberry PI elf->class equals KMOD_ELF_32|KMOD_ELF_LSB so
valid condition should be (elf->class & KMOD_ELF_32) instead of
(elf->class == KMOD_ELF_32).

This fixes "modprobe --dump-modversions" failing on 32b systems.

10 years agotestsuite: Fix uname() during glibc startup
Michal Marek [Thu, 6 Mar 2014 17:03:46 +0000 (18:03 +0100)]
testsuite: Fix uname() during glibc startup

In a specific configuration (chroot with the linux32 personality), the
modprobe_install_cmd_loop test failed, because the bash process handling
the install command segfaulted. The backtrace showed a uname() call
during libpthread initialization, at which point the environ pointer
hadn't been initialized yet:

Program terminated with signal SIGSEGV, Segmentation fault.
#0  0x080c1591 in getenv (name=<optimized out>,
    name@entry=0xf775f850 "TESTSUITE_UNAME_R") at getenv.c:81
81       for (i = 0, len = strlen (name); environ[i]; i++)
(gdb) bt
#0  0x080c1591 in getenv (name=<optimized out>,
    name@entry=0xf775f850 "TESTSUITE_UNAME_R") at getenv.c:81
#1  0xf775f754 in uname (u=u@entry=0xff946350) at testsuite/uname.c:32
#2  0xf74ffc6c in is_smp_system ()
    at ../nptl/sysdeps/unix/sysv/linux/i386/smp.h:39
#3  __pthread_initialize_minimal_internal () at nptl-init.c:460
#4  0xf74fe32c in _init () at ../sysdeps/i386/crti.S:74
#5  0x00000000 in ?? ()
(gdb) p environ
$1 = (char **) 0x0

I don't know why it only happend in the chroot, but glibc can call its
own functions and impose any restrictions before main() is started, so
we have to adapt.

Also, do not return error if there is an environment, but the
environment variable is not found. If uname() is called by kmod, then
the respective test will simply fail later. If it's something else
calling uname(), then we do not want to disturb the program.

10 years agoman: use systemd as example instead of udev
Lucas De Marchi [Thu, 6 Mar 2014 05:47:05 +0000 (02:47 -0300)]
man: use systemd as example instead of udev

Nowadays udev doesn't create nodes in /dev anymore. This role is rather
taken by systemd-tmpfiles on early boot so reference it generically as
systemd.

10 years agoman: clarify the support to modules.dep file
Lucas De Marchi [Thu, 6 Mar 2014 05:46:27 +0000 (02:46 -0300)]
man: clarify the support to modules.dep file

10 years agobuild-sys: Do not require xsltproc for installation of man pages
Lucas De Marchi [Mon, 24 Feb 2014 13:52:58 +0000 (10:52 -0300)]
build-sys: Do not require xsltproc for installation of man pages

Same reason as found in this commit to systemd:

commit 4ca39b280fce3c60d2fdecbd478fd9bf7f9d3e64
Author: Mike Gilbert <floppym@gentoo.org>
Date:   Sun Feb 23 11:21:13 2014 -0500

    configure: Do not require xsltproc for installation of man pages

    The release tarballs ship with pre-generated man pages, so we do not
    need xsltproc for a typical end-user build.

    Developers will probably have xsltproc anyway, but if not they will now
    encounter a build-time failure instead of an error in configure.

10 years agobuild-sys: add small redirecting Makefiles
Lucas De Marchi [Thu, 6 Mar 2014 04:51:33 +0000 (01:51 -0300)]
build-sys: add small redirecting Makefiles

These redirecting makefiles simplifies compiling from some editors and
when CWD is not the root of the source tree. This is similar to what was
introduced in systemd in 340d89e ("build-sys: add small redirecting
Makefiles to simplify compilation from within emacs")

10 years agotestsuite: add test for '.' correctly parsed in param's value
Lucas De Marchi [Thu, 6 Mar 2014 04:36:02 +0000 (01:36 -0300)]
testsuite: add test for '.' correctly parsed in param's value

In kcmdline it's possible to have a dot in the param's value. The
support for this was added in 66f3228 ("libkmod: Add support for '.' in
module parameter on kcmdline") and is needed to correctly support some
modules that depend on it.

This test was added in order to make sure the commit  aa87854
("libkmod-config: Only match dot before '=' in /proc/cmdline") didn't
break it. Although that commit  message says it's allowing to match a
dot before '=' it's actually enforcing the first part of the string to
be always in the format "<module-name>.param". Dots after '=' are still
correctly allowed.

10 years agotestsuite: add test to ignore unrelated strings in kcmdline
Lucas De Marchi [Thu, 6 Mar 2014 04:24:32 +0000 (01:24 -0300)]
testsuite: add test to ignore unrelated strings in kcmdline

Strings unrelated to modules and modprobe should be ignored and not
appear in the output of "modprobe -c".

This adds a test for the fix provided in aa87854 ("libkmod-config: Only
match dot before '=' in /proc/cmdline").

10 years agotestsuite: give a more suitable description to test
Lucas De Marchi [Thu, 6 Mar 2014 04:14:12 +0000 (01:14 -0300)]
testsuite: give a more suitable description to test

We are not only checking if those options are correctly parsed from
kcmdline, but if in fact they are being passed to the final
(f)init_module call. This is why we use 'modprobe --show-depends'
instead of the simpler 'modprobe -c'.

10 years agotestsuite: add test for kcmdline params with no value
Lucas De Marchi [Thu, 6 Mar 2014 04:09:30 +0000 (01:09 -0300)]
testsuite: add test for kcmdline params with no value

Use "modprobe -c" to dump the configuration. Since we configure our
rootfs to have only a /proc/cmdline file, this should dump the knowledge
we have from its parsed content.

Test if <module>.option, without any value is correctly parsed, as fixed
in commit 493dc65 ("libkmod: Fix getting param with no value from kcmdline")

10 years agolibkmod-config: Only match dot before '=' in /proc/cmdline
Michal Marek [Wed, 5 Mar 2014 12:27:41 +0000 (13:27 +0100)]
libkmod-config: Only match dot before '=' in /proc/cmdline

Otherwise, we also parse strings like

  BOOT_IMAGE=/boot/vmlinuz-3.12.12-57.g5f654cf-default

In practice, this is not a problem, because there is no module named
BOOT_IMAGE=/boot/vmlinuz-3. It just disturbs in modprobe -c output.

10 years agolibkmod-config,depmod: Accept special files as configuration files, too
Michal Marek [Tue, 4 Mar 2014 15:51:25 +0000 (16:51 +0100)]
libkmod-config,depmod: Accept special files as configuration files, too

If we can open it and read it, it's good enough for us. Otherwise, we
cannot use -C /dev/null to skip the system configuration for instance:

$ ./tools/modprobe -C /dev/null -c
libkmod: ERROR libkmod/libkmod-config.c:821 conf_files_list: unsupported
file mode /dev/null: 0x21b6
...

10 years agolibkmod-module: Simplify kmod_module_insert_module()
Michal Marek [Fri, 28 Feb 2014 12:05:32 +0000 (13:05 +0100)]
libkmod-module: Simplify kmod_module_insert_module()

Store the file and elf pointer in the kmod_module structure and have it
freed together with the module.

10 years agoAdd some tests for kernels without finit_module(2)
Michal Marek [Fri, 28 Feb 2014 12:05:31 +0000 (13:05 +0100)]
Add some tests for kernels without finit_module(2)

10 years agotestsuite: Do not provide finit_module(2) on older kernels
Michal Marek [Fri, 28 Feb 2014 12:05:30 +0000 (13:05 +0100)]
testsuite: Do not provide finit_module(2) on older kernels

If the test's uname -r is less that 3.8, return -ENOSYS from
finit_module(), so that the fallback is tested.

10 years agotestsuite: Add test for modprobe --force
Michal Marek [Fri, 28 Feb 2014 12:05:29 +0000 (13:05 +0100)]
testsuite: Add test for modprobe --force

There is no check if the correct flags are passed to finit_module, but
at least we cover the respective code path in kmod.

10 years agotestsuite: Check the list of loaded modules after a test
Michal Marek [Fri, 28 Feb 2014 12:05:28 +0000 (13:05 +0100)]
testsuite: Check the list of loaded modules after a test

Add a ->modules_loaded member to struct test, which is a comma-separated
list of modules that should be present after the test finishes. Both
missing and excess modules cause an error.

10 years agoRemove "rmmod -w" documentation and getopt entry
Stephen Kitt [Sun, 26 Jan 2014 20:00:23 +0000 (18:00 -0200)]
Remove "rmmod -w" documentation and getopt entry

This patch removes the cmdopts declaration and the documentation. They
were leftover from the -w removal.

10 years agoman: insmod documentation fix
Lukas Berk [Thu, 23 Jan 2014 19:08:58 +0000 (14:08 -0500)]
man: insmod documentation fix

Add comma between lsmod(8) and modinfo(8)

Signed-off-by: Lukas Berk <lberk@redhat.com>
10 years agoRemove duplicate includes
Lucas De Marchi [Tue, 21 Jan 2014 16:03:02 +0000 (14:03 -0200)]
Remove duplicate includes

Found by
https://raw.github.com/karelzak/util-linux/master/tools/checkincludes.pl

10 years agoman: Change my contact email address
Lucas De Marchi [Thu, 2 Jan 2014 19:13:38 +0000 (17:13 -0200)]
man: Change my contact email address

10 years agokmod 16 v16
Lucas De Marchi [Sun, 22 Dec 2013 21:45:19 +0000 (19:45 -0200)]
kmod 16

10 years agoUse C11's noreturn
Lucas De Marchi [Tue, 17 Dec 2013 21:10:16 +0000 (19:10 -0200)]
Use C11's noreturn

Also define noreturn w/o <stdnoreturn.h> and move it to macro.h instead
of in the testsuite.

Based on similar commit on systemd by Shawn Landden
<shawn@churchofgit.com>.

11 years agomodule: use _cleanup_free and remove useless call to free()
Lucas De Marchi [Mon, 18 Nov 2013 13:52:53 +0000 (11:52 -0200)]
module: use _cleanup_free and remove useless call to free()

11 years agofile: use _cleanup_free_
Lucas De Marchi [Mon, 18 Nov 2013 13:43:10 +0000 (11:43 -0200)]
file: use _cleanup_free_

11 years agoarray: avoid duplicate code to reallocate
Lucas De Marchi [Mon, 18 Nov 2013 13:28:28 +0000 (11:28 -0200)]
array: avoid duplicate code to reallocate

11 years agoutil: Be OOM-safe and use _cleanup_free_
Lucas De Marchi [Mon, 18 Nov 2013 07:31:14 +0000 (05:31 -0200)]
util: Be OOM-safe and use _cleanup_free_

11 years agotestsuite: add basic test for getline_wrapped
Lucas De Marchi [Mon, 18 Nov 2013 07:13:59 +0000 (05:13 -0200)]
testsuite: add basic test for getline_wrapped

11 years agoutil: use _cleanup_free_ on path_make_absolute_cwd()
Lucas De Marchi [Thu, 14 Nov 2013 06:16:16 +0000 (04:16 -0200)]
util: use _cleanup_free_ on path_make_absolute_cwd()

11 years agoconfig: Use _cleanup_free_
Lucas De Marchi [Thu, 14 Nov 2013 02:33:28 +0000 (00:33 -0200)]
config: Use _cleanup_free_

11 years agoutil: Add cleanup attribute
Lucas De Marchi [Thu, 14 Nov 2013 02:19:15 +0000 (00:19 -0200)]
util: Add cleanup attribute

11 years agotestsuite: Move test-alias to test-util
Lucas De Marchi [Mon, 18 Nov 2013 06:32:45 +0000 (04:32 -0200)]
testsuite: Move test-alias to test-util

Move file so we can use the same file to test other functions from
libkmod-util.c

11 years agobuild: Allow disabling maintainer mode
Anders Olofsson [Mon, 11 Nov 2013 01:41:25 +0000 (23:41 -0200)]
build: Allow disabling maintainer mode

This allows make rules for generated build files (i.e.  configure,
Makefile.in, ... ) to be skipped.  This is useful when
the source is stored without timestamps (for example in CVS or GIT).

When the build rules trigger to regenerate the build files, it tries to
use the same autotools version (currently 1.14) as was originally used
for the release.  Since many of our build machines run Debian Squeeze,
they only have autotools 1.11 available and the build fails.

Currently, we have to work around this by touching all the generated
files before building to avoid triggering the make rule. With this
patch, we would be able to just run configure with
--disable-maintainer-mode instead.  The patch sets the default to enable
to not change the default behavior.

11 years agobuild-sys: enable colored diagnostics if available
Lucas De Marchi [Sat, 26 Oct 2013 04:51:05 +0000 (02:51 -0200)]
build-sys: enable colored diagnostics if available

11 years agoMakefile.am: add mkdir testsuite
Saul Wold [Thu, 10 Oct 2013 06:49:48 +0000 (23:49 -0700)]
Makefile.am: add mkdir testsuite

If we are note building in the existing source tree and have disabled
dependency-tracking then the testsuite directory is not created during
the configure phase and will not exist when the cp of ROOTFS_PRISTINE
occurs, thus causing an error and fail.

11 years agoMakefile.am: Add target to all cross-compilation of testsuite
Saul Wold [Thu, 10 Oct 2013 01:09:52 +0000 (18:09 -0700)]
Makefile.am: Add target to all cross-compilation of testsuite

The buildtest-TESTS target allows for cross-compilation of the testsuites
without the actual running of the tests that check normally does.

11 years agoNEWS: add entries
Lucas De Marchi [Fri, 20 Sep 2013 06:50:40 +0000 (01:50 -0500)]
NEWS: add entries

11 years agormmod: remove --wait option
Lucas De Marchi [Fri, 20 Sep 2013 06:40:58 +0000 (01:40 -0500)]
rmmod: remove --wait option

Let libkmod enforce KMOD_REMOVE_NOWAIT.

11 years agolibkmod: always pass O_NONBLOCK to kernel
Lucas De Marchi [Fri, 20 Sep 2013 06:30:07 +0000 (01:30 -0500)]
libkmod: always pass O_NONBLOCK to kernel

Not passsing O_NONBLOCK to delete_module() is deprecated since kmod 11
and is being removed from the kernel. Force this flag in libkmod.

11 years agolibkmod-hash: always align n_buckets to power of 2
Lucas De Marchi [Thu, 22 Aug 2013 04:36:45 +0000 (01:36 -0300)]
libkmod-hash: always align n_buckets to power of 2

By aligning n_buckets to power of 2 we can turn the "bucket = hashval %
n_buckets" into a less expensive bucket = hashval & (n_buckets - 1).
This removes the DIV instruction as shown below.

Before:
xor    %edx,%edx
divl   0x8(%rbx)
mov    %edx,%eax
add    $0x1,%rax
shl    $0x4,%rax
add    %rbx,%rax

After:
lea    -0x1(%rdi),%edx
and    %edx,%eax
add    $0x1,%rax
shl    $0x4,%rax
add    %rbx,%rax

With a microbenchmark, measuring the time to locate the bucket (i.e.
time_to_calculate_hashval + time_to_calculate_bucket_position) we have
the results below (time in clock cycles):

keylen      before   after
2-10          79.0    61.9 (-21.65%)
11-17         81.0    64.4 (-20.48%)
18-25         90.0    73.2 (-18.69%)
26-32        104.7    87.0 (-16.82%)
33-40        108.4    89.6 (-17.37%)
41-48        111.2    91.9 (-17.38%)
49-55        120.1   102.1 (-15.04%)
56-63        134.4   115.7 (-13.91%)

As expected the gain is constant, regardless of the key length.
The time to clculate the hashval varies with the key length, which
explains the bigger gains for short keys.

11 years agoutil: Add ALIGN_POWER2
Lucas De Marchi [Thu, 22 Aug 2013 04:10:13 +0000 (01:10 -0300)]
util: Add ALIGN_POWER2

Add static inline function to align a value to it's next power of 2.
This is commonly done by a SWAR like the one in:

http://aggregate.org/MAGIC/#Next Largest Power of 2

However a microbench shows that the implementation herer is a faster.
It doesn't really impact the possible user of this function, but it's
interesting nonetheless.

Using a x86_64 i7 Ivy Bridge it shows a ~4% advantage by using clz
instead instead of the OR and SHL chain. And this is by using a BSR
since Ivy Bridge doesn't have LZCNT. New Haswell processors have the
LZCNT instruction which can make this even better. ARM also has a CLZ
instruction so it should be better, too.

Code used to test:

...
v = val[i];
t1 = get_cycles(0);
a = ALIGN_POWER2(v);
t1 = get_cycles(t1);

t2 = get_cycles(0);
v = nlpo2(v);
t2 = get_cycles(t2);

printf("%u\t%llu\t%llu\t%d\n", v, t1, t2, v == a);
...

In which val is an array of 20 random unsigned int, nlop2 is the SWAR
implementation and get_cycles uses RDTSC to measure the performance.

Averages:
ALIGN_POWER2:  30 cycles
nlop2: 31.4 cycles

11 years agodepmod: warn on invalid devname specification
Tom Gundersen [Mon, 9 Sep 2013 18:01:01 +0000 (20:01 +0200)]
depmod: warn on invalid devname specification

During the last merge window (3.12) a couple of modules gained devname
aliases, but without the necessary major and minor information. These were
then silently ignored when generating modules.devname.

Complain loudly to avoid such errors sneaking in undetected in the future:

    depmod: ERROR: Module 'zram' has devname (zram) but lacks major and minor information. Ignoring.
    depmod: ERROR: Module 'uhid' has devname (uhid) but lacks major and minor information. Ignoring.

Cc: Kay Sievers <kay@vrfy.org>
Cc: Lucas De Marchi <lucas.demarchi@profusion.mobi>
11 years agobuild: remove check for typeof
Lucas De Marchi [Fri, 6 Sep 2013 14:15:02 +0000 (11:15 -0300)]
build: remove check for typeof

It's used in so many places without checking, that's really pointless to
check for it in macro.h.

Also remove AC_C_TYPEOF from configure.ac since we don't use -ansi.

11 years agoAdd configure check for _Static_assert()
Thomas Petazzoni [Fri, 6 Sep 2013 13:27:04 +0000 (15:27 +0200)]
Add configure check for _Static_assert()

Commit 8efede20ef ("Use _Static_assert") introduced the usage of
_Static_assert(). However, _Static_assert() is a fairly new thing,
since it was introduced only in gcc 4.6. In order to support older
compilers, this patch adds a configure.in test that checks whether
_Static_assert() is usable or not, and adjust the behavior of the
assert_cc() macro accordingly.

11 years agoFix usage of readdir_r()
Lucas De Marchi [Wed, 28 Aug 2013 02:29:47 +0000 (23:29 -0300)]
Fix usage of readdir_r()

With readdir_r() we should be providing enough space to store the dir
name. This could be accomplished by define an union like systemd does:

union dirent_storage {
struct dirent de;
uint8_t storage[offsetof(struct dirent, d_name) +
((NAME_MAX + 1 + sizeof(long)) & ~(sizeof(long) - 1))];
};

However in all places that we use readdir_r() we have no concerns about
reentrance nor we have problems with threads. Thus use the simpler
readdir() instead.

We also remove the error logging here (that could be added back by
checking errno), but it was not adding much value so it's gone.

11 years agotestsuite: fix usage of reserved names
John Spencer [Mon, 26 Aug 2013 23:38:11 +0000 (01:38 +0200)]
testsuite: fix usage of reserved names

stdout and stderr are names reserved for the implementation
and musl uses them rightfully as macro - and the expansion
causes (of course) unexpected results.

rename the struct members stdout to out and stderr
to err, to be 1) compliant 2) cause compilation to
succeed.

fixes build with musl libc.

11 years agokmod 15 v15
Lucas De Marchi [Thu, 22 Aug 2013 13:44:08 +0000 (10:44 -0300)]
kmod 15

11 years agolibkmod: Fix getting param with no value from kcmdline
Lucas De Marchi [Wed, 14 Aug 2013 01:04:46 +0000 (22:04 -0300)]
libkmod: Fix getting param with no value from kcmdline

11 years agotestsuite: Add test for parameter with no value in kcmdline
Lucas De Marchi [Wed, 14 Aug 2013 01:03:26 +0000 (22:03 -0300)]
testsuite: Add test for parameter with no value in kcmdline

Currently we fail to add the module option if the parameter doesn't have
a value.

11 years agodepmod: add missing "else" clause
Jan Engelhardt [Wed, 7 Aug 2013 21:58:58 +0000 (23:58 +0200)]
depmod: add missing "else" clause

It occurred to an openSUSE user that our mkinitrd would throw a
warning when used with kmod:

libkmod: conf_files_list: unsupported file mode /dev/null: 0x21b6

Grepping for the error message revealed that there might be a missing
"else" keyword here, since it is unusual to put an "if" directly after
closing brace.

11 years agoshell-completion: Make options accept '=' as last char
Lucas De Marchi [Fri, 2 Aug 2013 15:07:39 +0000 (12:07 -0300)]
shell-completion: Make options accept '=' as last char

11 years agobuild: Install bash completion data
Lucas De Marchi [Tue, 30 Jul 2013 06:47:19 +0000 (03:47 -0300)]
build: Install bash completion data

11 years agoshell-completion: Add kmod static-nodes
Lucas De Marchi [Tue, 30 Jul 2013 06:28:41 +0000 (03:28 -0300)]
shell-completion: Add kmod static-nodes

11 years agoshell-completion: Add initial completion for kmod
Lucas De Marchi [Mon, 29 Jul 2013 16:23:54 +0000 (13:23 -0300)]
shell-completion: Add initial completion for kmod

Based on journalctl and udevadm from systemd and adapted to kmod needs.

11 years agoNEWS: Add entries
Lucas De Marchi [Wed, 17 Jul 2013 05:31:36 +0000 (02:31 -0300)]
NEWS: Add entries

11 years agoREADME: Move items from TODO
Lucas De Marchi [Wed, 17 Jul 2013 05:26:47 +0000 (02:26 -0300)]
README: Move items from TODO

Put the differences between kmod and module-init-tools in the README
file so it's more visible.

11 years agostatic-nodes: create parent directories of output file
Tom Gundersen [Sun, 14 Jul 2013 13:13:34 +0000 (15:13 +0200)]
static-nodes: create parent directories of output file

Allows us to drop call to "mkdir -p" from the systemd service file.

11 years agoutil: Add mkdir_parents()
Lucas De Marchi [Mon, 15 Jul 2013 05:05:52 +0000 (02:05 -0300)]
util: Add mkdir_parents()

Like mkdir_p, but discards the leaf, creating the parent directories.

11 years agoutil: Add len arg to mkdir_p()
Lucas De Marchi [Mon, 15 Jul 2013 04:58:44 +0000 (01:58 -0300)]
util: Add len arg to mkdir_p()

11 years agostatic-nodes: don't fail if modules.devname not found
Tom Gundersen [Sun, 14 Jul 2013 13:13:33 +0000 (15:13 +0200)]
static-nodes: don't fail if modules.devname not found

In containers/VM's/initrd one might not have installed any modules and
accompanying modules.devname Don't fail if this is the case, just warn.

When used in systemd this means we don't get a failing unit on booting
containers.

11 years agoutil: Add mkdir_p implementation from testsuite
Lucas De Marchi [Mon, 15 Jul 2013 04:41:19 +0000 (01:41 -0300)]
util: Add mkdir_p implementation from testsuite

11 years agotestsuite: Fix mkdir_p corner cases
Lucas De Marchi [Mon, 15 Jul 2013 04:21:27 +0000 (01:21 -0300)]
testsuite: Fix mkdir_p corner cases

 - Fix infinite loop when path is relative
 - Fix not considering EEXIST as a success
 - General refactor to mkdir_p so it never calls mkdir for an existing
   dir (given no one creates it from outside)

11 years agoUse "-internal" suffix instead of "-private"
Lucas De Marchi [Thu, 4 Jul 2013 19:13:11 +0000 (16:13 -0300)]
Use "-internal" suffix instead of "-private"

11 years agotools: Do not link dynamically with libkmod
Lucas De Marchi [Thu, 4 Jul 2013 19:01:55 +0000 (16:01 -0300)]
tools: Do not link dynamically with libkmod

Instead of linking dynamically with libkmod, use libkmod-private.la. We
disallow creating a static libkmod because we can't hide symbols there
and it cause problems with external programs. However this should not
prevent users that are only interested in the tools we provide not being
able to ship only them keeping the library alone.

Other projects also do this to allow our tools to use certain functions
that should not be used outside of the project.

11 years agokmod 14 v14
Lucas De Marchi [Wed, 3 Jul 2013 15:42:04 +0000 (12:42 -0300)]
kmod 14

11 years agotools: Use test/kmod instead of kmod-nolib
Lucas De Marchi [Wed, 3 Jul 2013 00:03:20 +0000 (21:03 -0300)]
tools: Use test/kmod instead of kmod-nolib

The reason to have a kmod-nolib binary is that we need to call kmod on
test cases (or a symlink to it) and for testing things in tree. Since
we are using libtool if we are dinamically linking to libkmod what we
end up having is a shell script that (depending on the version *)
changes argv[0] to contain an "lt-" prefix. Since this screws with our
compat stuff, we had a kmod-nolib that links statically.

This all workaround works fine iff we are using one of the compat
commands, i.e. we are using the symlinks insmod, rmmod, modprobe, etc.
However if we are actually trying the kmod binary, this doesn't work
because we can't create a kmod symlink since there's already a kmod
binary.

So, completely give up on libtool fixing their mess. Now we create a
tool/test/ directory and the symlinks and kmod is put there.

* http://lists.gnu.org/archive/html/bug-libtool/2011-12/msg00023.html

11 years agostatic-nodes: Better -f option description
Lucas De Marchi [Tue, 2 Jul 2013 02:00:20 +0000 (23:00 -0300)]
static-nodes: Better -f option description

11 years agobuild-sys: do not allow --enable static
Lucas De Marchi [Thu, 6 Jun 2013 14:43:19 +0000 (11:43 -0300)]
build-sys: do not allow --enable static

Do the same as done in systemd by Cristian Rodríguez
<crrodriguez@opensuse.org>. We use private symbols, not namespaced. So
don't pretend we support static linking.

11 years agoAdd travis-ci config file
Lucas De Marchi [Tue, 30 Apr 2013 03:21:21 +0000 (00:21 -0300)]
Add travis-ci config file

Experiment with a build bot.

11 years agolibkmod: Avoid calling syscall() with -1
Jan Luebbe [Thu, 2 May 2013 14:47:12 +0000 (16:47 +0200)]
libkmod: Avoid calling syscall() with -1

At least in qemu 1.4.1 for vexpress/arm-cortexa9, this resulted in an
illegal instruction error. Solve that by returning an error when
__NR_finit_module is -1.

11 years agoRevert "missing: Don't call syscall() with syscallno == -1"
Lucas De Marchi [Sat, 11 May 2013 03:50:32 +0000 (00:50 -0300)]
Revert "missing: Don't call syscall() with syscallno == -1"

This reverts commit 38829712e5c411bc250aeae142fc6bf06e794d58.  It fixes
the problem, but it breaks the testsuite for those who don't have
__NR_finit_module. The testsuite would have to make the same check.

Instead, I'm reverting this change and I'm going to apply another patch
from Jan Luebbe who got this right from the beginning.

11 years agoAdd document for exported enums
Chengwei Yang [Sat, 4 May 2013 09:07:03 +0000 (17:07 +0800)]
Add document for exported enums

There are several exported enums by libkmod without document, this patch
mainly added documentation for below enums like the way kmod_resources
be documented in.
* kmod_index
* kmod_remove
* kmod_insert
* kmod_probe
* kmod_filter
* kmod_module_initstate

This is not the best way to document these exported enums, however, it's
the simple way due to gtkdoc limits. It doesn't support export plain
enum like below: see https://bugzilla.gnome.org/show_bug.cgi?id=657444
---------8<-------head.h--------------8<-----------
...
enum foo {
    ...
};
...
---------8<-------end of head.h-------8<-----------
---------8<-------source.c------------8<-----------
...
/**
 * document for foo here
 */
...
typedef enum foo foo;
...
---------8<-------end of source.c-----8<----------

11 years agoSeveral minor fixes for documentation
Chengwei Yang [Sat, 4 May 2013 09:07:02 +0000 (17:07 +0800)]
Several minor fixes for documentation

11 years agomodprobe: don't check refcount with remove command
Johannes Berg [Thu, 2 May 2013 13:23:28 +0000 (15:23 +0200)]
modprobe: don't check refcount with remove command

The modprobe.d (5) documentation for the "install" command
states that you could specify

install fred /sbin/modprobe barney; /sbin/modprobe --ignore-install fred

This makes some sense, but then the loading of "barney" is
hidden from the user who did only "modprobe fred". Thus,
it seems it should be possible to be able to unload the
"fred" module with "modprobe -r fred" by configuring the
"barney" module to also be removed:

remove fred /sbin/rmmod barney fred

(or similar.)

Make this possible by not checking the refcount when an
unload command was configured.

Reported-by: David Spinadel <david.spinadel@intel.com>
11 years agomissing: Don't call syscall() with syscallno == -1
Lucas De Marchi [Thu, 2 May 2013 16:22:57 +0000 (13:22 -0300)]
missing: Don't call syscall() with syscallno == -1

Reported-by: Jean-Francis Roy <jeanfrancis@funtoo.org>
Reported-by: Jan Luebbe <jlu@pengutronix.de>
11 years agoFix coding style
Lucas De Marchi [Tue, 30 Apr 2013 15:34:55 +0000 (12:34 -0300)]
Fix coding style

Either with space or without, not a mix of both.

11 years agoTODO: Add some entries
Lucas De Marchi [Tue, 30 Apr 2013 15:34:23 +0000 (12:34 -0300)]
TODO: Add some entries

11 years agolibkmod-index: Return early if readroot failed
Lucas De Marchi [Wed, 24 Apr 2013 00:21:00 +0000 (21:21 -0300)]
libkmod-index: Return early if readroot failed

11 years agolibkmod-module: Don't pass NULL ctx to kmod_log
Lucas De Marchi [Tue, 23 Apr 2013 23:47:28 +0000 (20:47 -0300)]
libkmod-module: Don't pass NULL ctx to kmod_log

11 years agolibkmod-module: Don't pass NULL pointer to memcpy
Lucas De Marchi [Tue, 23 Apr 2013 23:33:13 +0000 (20:33 -0300)]
libkmod-module: Don't pass NULL pointer to memcpy

When passing n=0, don't pass a NULL pointer, but instead pass anything
else (like the pointer to the start of the string).

11 years agobuild-sys: Add AM_V_XSLT to rule creating man pages
Lucas De Marchi [Sun, 21 Apr 2013 19:33:54 +0000 (16:33 -0300)]
build-sys: Add AM_V_XSLT to rule creating man pages

11 years agoAdd format attribute and fix issues
Lucas De Marchi [Sun, 21 Apr 2013 19:16:18 +0000 (16:16 -0300)]
Add format attribute and fix issues

Add __attribute__((format)) to log_filep() and _show() functions, fixing
the bugs they found in the source code.

For functions that receive va_list instead of being variadic functions
we put 0 in the last argument, so at least the string is checked and we
get warnings of -Wformat-nonliteral type. So, it's better than adding a
pragma here to shut up the warning.

11 years agostatic-nodes: Fix indentation
Lucas De Marchi [Fri, 19 Apr 2013 22:08:43 +0000 (19:08 -0300)]
static-nodes: Fix indentation

kmod uses tab instead of spaces and tries to honour 80chr limit, when
that doesn't worsen the readability.

11 years agostatic-nodes: tmpfiles - also create parents directories of device nodes
Tom Gundersen [Fri, 19 Apr 2013 21:53:35 +0000 (23:53 +0200)]
static-nodes: tmpfiles - also create parents directories of device nodes

Before:

c /dev/cpu/microcode 0600 - - - 10:184
c /dev/fuse 0600 - - - 10:229
c /dev/btrfs-control 0600 - - - 10:234
c /dev/loop-control 0600 - - - 10:237
c /dev/snd/timer 0600 - - - 116:33

After:

d /dev/cpu 0755 - - -
c /dev/cpu/microcode 0600 - - - 10:184
c /dev/fuse 0600 - - - 10:229
c /dev/btrfs-control 0600 - - - 10:234
c /dev/loop-control 0600 - - - 10:237
d /dev/snd 0755 - - -
c /dev/snd/timer 0600 - - - 116:33

11 years agokmod: It's an error not to have modules.devname
Lucas De Marchi [Wed, 17 Apr 2013 03:54:17 +0000 (00:54 -0300)]
kmod: It's an error not to have modules.devname

This file is created by depmod even if there's no node. In this case it
will be empty.

Previously 'kmod static-nodes' was segfaulting due to passing in==NULL
to fgets.

Also show the error message with %m.

11 years agotools: add static-nodes tool
Tom Gundersen [Tue, 16 Apr 2013 20:39:55 +0000 (22:39 +0200)]
tools: add static-nodes tool

This tool reads modules.devname from the current kernel directory and outputs
the information. By default in a human-readable format, and optionally in
machine-readable formats.

For now only the tmpfiles.d(5) format is supported, but more could easily be
added in the future if there is a need.

This means nothing but kmod needs to reads the private files under
/lib/modules/. In particular systemd-udevd can stop reading modules.devname.

Tools that used to read /lib/modules/`uname -r`/modules.devname directly, can
now move to reading 'kmod static-nodes devname'.

11 years agoUse static assertions for sizeof checks
Lucas De Marchi [Mon, 15 Apr 2013 17:14:07 +0000 (14:14 -0300)]
Use static assertions for sizeof checks

11 years agoUse _Static_assert
Lucas De Marchi [Mon, 15 Apr 2013 17:09:05 +0000 (14:09 -0300)]
Use _Static_assert

Both GCC and clang already supports C11's _Static_assert, so use it
instead of defining our own macro.

11 years agotestsuite: errno is a positive number
Lucas De Marchi [Fri, 12 Apr 2013 04:24:30 +0000 (01:24 -0300)]
testsuite: errno is a positive number

11 years agoTODO: update and reorder
Lucas De Marchi [Tue, 9 Apr 2013 23:20:38 +0000 (20:20 -0300)]
TODO: update and reorder

11 years agokmod 13 v13
Lucas De Marchi [Tue, 9 Apr 2013 22:35:32 +0000 (19:35 -0300)]
kmod 13

11 years agobuild-sys: Always enable parallel tests
Lucas De Marchi [Tue, 9 Apr 2013 14:59:33 +0000 (11:59 -0300)]
build-sys: Always enable parallel tests

Automake < 1.13 doesn't enable parallel tests by default, so add it to our
automake options.

11 years agotestsuite: Fix checking __sysno
Lucas De Marchi [Tue, 9 Apr 2013 14:54:05 +0000 (11:54 -0300)]
testsuite: Fix checking __sysno

Use an if instead of a case statemente. If __NR_finit_module is not
defined in system headers we define it to -1, causing a "duplicate case
value" error. Yet, we don't want to actually call our finit_module()
function if -1 is passed.

This also fix errno being set with negative value.

11 years agotestsuite: Wrap syscall() to get calls to finit_module()
Lucas De Marchi [Tue, 9 Apr 2013 08:21:42 +0000 (05:21 -0300)]
testsuite: Wrap syscall() to get calls to finit_module()

When we don't have finit_module() in libc (most likely because as of
today glibc didn't add it yet), we end up using
syscall(__NR_finit_module, ...). In this case we would not wrap the
function in the testsuite and thus having some tests failing:

TESTSUITE: ERR: could not insert module: Operation not permitted

This implementation relies on the fact that this is the only caller of
syscall(2), because we can't call libc's syscall(). There's an abort()
in place to be future safe: as soon as we need more calls to syscall(),
we can detect (and decide what to do).

Now we have all tests passing in the testsuite again.

11 years agolibkmod: Move finit_module() definition to missing.h
Lucas De Marchi [Tue, 9 Apr 2013 07:16:57 +0000 (04:16 -0300)]
libkmod: Move finit_module() definition to missing.h

Check for finit_module() and don't use our own static inline function if
there's such function in libc (or another lib).

In testsuite we need to unconditionally define HAVE_FINIT_MODULE because
we want to override this function, and never use the static inline one
in missing.h