Compare commits
2 Commits
master
...
kmod-lib-m
Author | SHA1 | Date | |
---|---|---|---|
![]() |
0bb35d5d4f | ||
![]() |
0fe84d6eed |
|
@ -82,8 +82,7 @@ stdenv.mkDerivation {
|
||||||
|
|
||||||
# Install kernel module
|
# Install kernel module
|
||||||
cd src
|
cd src
|
||||||
kernelVersion=$(cd ${kernel}/lib/modules; ls)
|
export MODULE_DIR=$out/lib/modules/${kernel.modDirVersion}/misc
|
||||||
export MODULE_DIR=$out/lib/modules/$kernelVersion/misc
|
|
||||||
|
|
||||||
# Remove root ownership stuff, since this does not work in a chroot environment
|
# Remove root ownership stuff, since this does not work in a chroot environment
|
||||||
for i in `find . -name Makefile`; do
|
for i in `find . -name Makefile`; do
|
||||||
|
|
|
@ -114,12 +114,11 @@ stdenv.mkDerivation {
|
||||||
for i in *
|
for i in *
|
||||||
do
|
do
|
||||||
cd $i
|
cd $i
|
||||||
kernelVersion=$(cd ${kernel}/lib/modules; ls)
|
export MODULE_DIR=$out/lib/modules/${kernel.modDirVersion}/misc
|
||||||
export MODULE_DIR=$out/lib/modules/$kernelVersion/misc
|
find . -type f | xargs sed -i -e "s|-o root||g" \
|
||||||
find . -type f | xargs sed -i -e "s|-o root||g" \
|
-e "s|-g root||g"
|
||||||
-e "s|-g root||g"
|
make install
|
||||||
make install
|
cd ..
|
||||||
cd ..
|
|
||||||
done
|
done
|
||||||
'';
|
'';
|
||||||
|
|
||||||
|
|
|
@ -1,15 +1,15 @@
|
||||||
# Given a kernel build (with modules in $kernel/lib/modules/VERSION),
|
# Given a modules tree (with modules in $modulesTree/lib/modules/VERSION),
|
||||||
# produce a module tree in $out/lib/modules/VERSION that contains only
|
# produce a module tree in $out/lib/modules/VERSION that contains only
|
||||||
# the modules identified by `rootModules', plus their dependencies.
|
# the modules identified by `rootModules', plus their dependencies.
|
||||||
# Also generate an appropriate modules.dep.
|
# Also generate an appropriate modules.dep.
|
||||||
|
|
||||||
{ stdenv, kernel, nukeReferences, rootModules
|
{ stdenv, modulesTree, nukeReferences, rootModules
|
||||||
, module_init_tools, allowMissing ? false }:
|
, kmod, allowMissing ? false }:
|
||||||
|
|
||||||
stdenv.mkDerivation {
|
stdenv.mkDerivation {
|
||||||
name = kernel.name + "-shrunk";
|
name = modulesTree.name + "-shrunk";
|
||||||
builder = ./modules-closure.sh;
|
builder = ./modules-closure.sh;
|
||||||
buildInputs = [nukeReferences];
|
buildInputs = [nukeReferences];
|
||||||
inherit kernel rootModules module_init_tools allowMissing;
|
inherit modulesTree rootModules kmod allowMissing;
|
||||||
allowedReferences = ["out"];
|
allowedReferences = ["out"];
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,19 +2,17 @@ source $stdenv/setup
|
||||||
|
|
||||||
set -o pipefail
|
set -o pipefail
|
||||||
|
|
||||||
PATH=$module_init_tools/sbin:$PATH
|
PATH=$kmod/sbin:$PATH
|
||||||
|
version=$(cd $modulesTree/lib/modules && ls -d *)
|
||||||
version=$(cd $kernel/lib/modules && ls -d *)
|
|
||||||
|
|
||||||
echo "kernel version is $version"
|
echo "kernel version is $version"
|
||||||
|
|
||||||
export MODULE_DIR=$(readlink -f $kernel/lib/modules/)
|
mkdir empty
|
||||||
|
|
||||||
# Determine the dependencies of each root module.
|
# Determine the dependencies of each root module.
|
||||||
closure=
|
closure=
|
||||||
for module in $rootModules; do
|
for module in $rootModules; do
|
||||||
echo "root module: $module"
|
echo "root module: $module"
|
||||||
deps=$(modprobe --config /dev/null --set-version "$version" --show-depends "$module" \
|
deps=$(modprobe -S "$version" -d "$modulesTree" --show-depends "$module" \
|
||||||
| sed 's/^insmod //') \
|
| sed 's/^insmod //') \
|
||||||
|| if test -z "$allowMissing"; then exit 1; fi
|
|| if test -z "$allowMissing"; then exit 1; fi
|
||||||
#for i in $deps; do echo $i; done
|
#for i in $deps; do echo $i; done
|
||||||
|
@ -41,4 +39,4 @@ for module in $closure; do
|
||||||
echo $target >> $out/insmod-list
|
echo $target >> $out/insmod-list
|
||||||
done
|
done
|
||||||
|
|
||||||
MODULE_DIR=$out/lib/modules/ depmod -a $version
|
depmod -b $out -a $version
|
||||||
|
|
|
@ -70,14 +70,8 @@ installPhase() {
|
||||||
cp vmlinux $out
|
cp vmlinux $out
|
||||||
|
|
||||||
if grep -q "CONFIG_MODULES=y" .config; then
|
if grep -q "CONFIG_MODULES=y" .config; then
|
||||||
# Install the modules in $out/lib/modules with matching paths
|
|
||||||
# in modules.dep (i.e., refererring to $out/lib/modules, not
|
|
||||||
# /lib/modules). The depmod_opts= is to prevent the kernel
|
|
||||||
# from passing `-b PATH' to depmod.
|
|
||||||
export MODULE_DIR=$out/lib/modules/
|
|
||||||
substituteInPlace Makefile --replace '-b $(INSTALL_MOD_PATH)' ''
|
|
||||||
make modules_install \
|
make modules_install \
|
||||||
DEPMOD=$module_init_tools/sbin/depmod depmod_opts= \
|
DEPMOD=$module_init_tools/sbin/depmod \
|
||||||
$makeFlags "${makeFlagsArray[@]}" \
|
$makeFlags "${makeFlagsArray[@]}" \
|
||||||
$installFlags "${installFlagsArray[@]}"
|
$installFlags "${installFlagsArray[@]}"
|
||||||
|
|
||||||
|
|
|
@ -229,10 +229,6 @@ import ./generic.nix (
|
||||||
rec {
|
rec {
|
||||||
version = "3.0.24";
|
version = "3.0.24";
|
||||||
|
|
||||||
preConfigure = ''
|
|
||||||
substituteInPlace scripts/depmod.sh --replace '-b "$INSTALL_MOD_PATH"' ""
|
|
||||||
'';
|
|
||||||
|
|
||||||
src = fetchurl {
|
src = fetchurl {
|
||||||
url = "mirror://kernel/linux/kernel/v3.x/linux-${version}.tar.bz2";
|
url = "mirror://kernel/linux/kernel/v3.x/linux-${version}.tar.bz2";
|
||||||
sha256 = "0j783ivlgg66jvasxaapimyzaqyn61jlz4abhkynckr4h5hrpvw4";
|
sha256 = "0j783ivlgg66jvasxaapimyzaqyn61jlz4abhkynckr4h5hrpvw4";
|
||||||
|
|
|
@ -229,10 +229,6 @@ import ./generic.nix (
|
||||||
rec {
|
rec {
|
||||||
version = "3.1.10";
|
version = "3.1.10";
|
||||||
|
|
||||||
preConfigure = ''
|
|
||||||
substituteInPlace scripts/depmod.sh --replace '-b "$INSTALL_MOD_PATH"' ""
|
|
||||||
'';
|
|
||||||
|
|
||||||
src = fetchurl {
|
src = fetchurl {
|
||||||
url = "mirror://kernel/linux/kernel/v3.x/linux-${version}.tar.bz2";
|
url = "mirror://kernel/linux/kernel/v3.x/linux-${version}.tar.bz2";
|
||||||
sha256 = "1vcpbh7wnc9smw2l5ci27a5p0rgmc1a5dc6a1aljm6f6wcfic8lz";
|
sha256 = "1vcpbh7wnc9smw2l5ci27a5p0rgmc1a5dc6a1aljm6f6wcfic8lz";
|
||||||
|
|
|
@ -231,10 +231,6 @@ import ./generic.nix (
|
||||||
|
|
||||||
modDirVersion = version;
|
modDirVersion = version;
|
||||||
|
|
||||||
preConfigure = ''
|
|
||||||
substituteInPlace scripts/depmod.sh --replace '-b "$INSTALL_MOD_PATH"' ""
|
|
||||||
'';
|
|
||||||
|
|
||||||
src = fetchurl {
|
src = fetchurl {
|
||||||
url = "mirror://kernel/linux/kernel/v3.0/${if testing then "testing/" else ""}linux-${version}.tar.bz2";
|
url = "mirror://kernel/linux/kernel/v3.0/${if testing then "testing/" else ""}linux-${version}.tar.bz2";
|
||||||
sha256 = "1hacfmf08ydzf4xlg6wkkckl5icj7w9h3nh17myz1s67bp7q61qs";
|
sha256 = "1hacfmf08ydzf4xlg6wkkckl5icj7w9h3nh17myz1s67bp7q61qs";
|
||||||
|
|
|
@ -231,10 +231,6 @@ import ./generic.nix (
|
||||||
|
|
||||||
modDirVersion = "3.3.0";
|
modDirVersion = "3.3.0";
|
||||||
|
|
||||||
preConfigure = ''
|
|
||||||
substituteInPlace scripts/depmod.sh --replace '-b "$INSTALL_MOD_PATH"' ""
|
|
||||||
'';
|
|
||||||
|
|
||||||
src = fetchurl {
|
src = fetchurl {
|
||||||
url = "mirror://kernel/linux/kernel/v3.0/${if testing then "testing/" else ""}linux-${version}.tar.bz2";
|
url = "mirror://kernel/linux/kernel/v3.0/${if testing then "testing/" else ""}linux-${version}.tar.bz2";
|
||||||
sha256 = "0czk8bj46r3r95iz6gi7xkavhjx847s5p9248vabi0c1wjs6kmlg";
|
sha256 = "0czk8bj46r3r95iz6gi7xkavhjx847s5p9248vabi0c1wjs6kmlg";
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
{stdenv, module_init_tools, modules, buildEnv}:
|
{stdenv, kmod, modules, buildEnv}:
|
||||||
|
|
||||||
buildEnv {
|
buildEnv {
|
||||||
name = "kernel-modules";
|
name = "kernel-modules";
|
||||||
|
@ -21,7 +21,8 @@ buildEnv {
|
||||||
# kernel version number, otherwise depmod will use `uname -r'.
|
# kernel version number, otherwise depmod will use `uname -r'.
|
||||||
if test -w $out/lib/modules/$kernelVersion; then
|
if test -w $out/lib/modules/$kernelVersion; then
|
||||||
rm -f $out/lib/modules/$kernelVersion/modules.*
|
rm -f $out/lib/modules/$kernelVersion/modules.*
|
||||||
MODULE_DIR=$out/lib/modules/ ${module_init_tools}/sbin/depmod -a $kernelVersion
|
echo ${kmod}/sbin/depmod -b $out -a $kernelVersion
|
||||||
|
${kmod}/sbin/depmod -b $out -a $kernelVersion
|
||||||
fi
|
fi
|
||||||
'';
|
'';
|
||||||
}
|
}
|
|
@ -8,10 +8,18 @@ stdenv.mkDerivation {
|
||||||
sha256 = "1xvsy2zcfdimj4j5b5yyxaqx2byabmwq8qlzjm0hqzpyxxgfw1lq";
|
sha256 = "1xvsy2zcfdimj4j5b5yyxaqx2byabmwq8qlzjm0hqzpyxxgfw1lq";
|
||||||
};
|
};
|
||||||
|
|
||||||
buildInputs = [ pkgconfig xz zlib ];
|
buildInputs = [ xz zlib ];
|
||||||
|
buildNativeInputs = [ pkgconfig ];
|
||||||
|
|
||||||
configureFlags = [ "--with-xz" "--with-zlib" ];
|
configureFlags = [ "--with-xz" "--with-zlib" ];
|
||||||
|
|
||||||
|
postInstall = ''
|
||||||
|
mkdir -p $out/sbin
|
||||||
|
for i in depmod insmod lsmod modinfo modprobe rmmod; do
|
||||||
|
ln -sv ../bin/kmod $out/sbin/$i
|
||||||
|
done
|
||||||
|
'';
|
||||||
|
|
||||||
meta = {
|
meta = {
|
||||||
homepage = http://www.kernel.org/pub/linux/utils/kernel/kmod/;
|
homepage = http://www.kernel.org/pub/linux/utils/kernel/kmod/;
|
||||||
description = "Tools for loading and managing Linux kernel modules";
|
description = "Tools for loading and managing Linux kernel modules";
|
||||||
|
|
|
@ -1,34 +0,0 @@
|
||||||
{ stdenv, fetchurl, docbook2x, docbook_sgml_dtd_41 }:
|
|
||||||
|
|
||||||
stdenv.mkDerivation {
|
|
||||||
name = "module-init-tools-3.16";
|
|
||||||
|
|
||||||
src = [
|
|
||||||
(fetchurl {
|
|
||||||
url = mirror://kernel/linux/utils/kernel/module-init-tools/module-init-tools-3.16.tar.bz2;
|
|
||||||
sha256 = "0jxnz9ahfic79rp93l5wxcbgh4pkv85mwnjlbv1gz3jawv5cvwp1";
|
|
||||||
})
|
|
||||||
|
|
||||||
# Upstream forgot to include the generated manpages. Thankfully
|
|
||||||
# the Gentoo people fixed this for us :-)
|
|
||||||
(fetchurl {
|
|
||||||
url = mirror://gentoo/distfiles/module-init-tools-3.16-man.tar.bz2;
|
|
||||||
sha256 = "1j1nzi87kgsh4scl645fhwhjvljxj83cmdasa4n4p5krhasgw358";
|
|
||||||
})
|
|
||||||
];
|
|
||||||
|
|
||||||
SGML_CATALOG_FILES = "${docbook_sgml_dtd_41}/sgml/dtd/docbook-4.1/docbook.cat";
|
|
||||||
|
|
||||||
patches = [ ./module-dir.patch ./docbook2man.patch ];
|
|
||||||
|
|
||||||
postInstall = "rm $out/sbin/insmod.static"; # don't need it
|
|
||||||
|
|
||||||
# We don't want bash (and therefore glibc) in the closure of the
|
|
||||||
# output, since we want to put this in a initrd.
|
|
||||||
dontPatchShebangs = stdenv ? isDietLibC;
|
|
||||||
|
|
||||||
meta = {
|
|
||||||
homepage = http://www.kernel.org/pub/linux/utils/kernel/module-init-tools/;
|
|
||||||
description = "Tools for loading and managing Linux kernel modules";
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,12 +0,0 @@
|
||||||
diff -Naur module-init-tools-3.16-orig/Makefile.in module-init-tools-3.16/Makefile.in
|
|
||||||
--- module-init-tools-3.16-orig/Makefile.in 2011-06-02 13:56:45.000000000 -0400
|
|
||||||
+++ module-init-tools-3.16/Makefile.in 2011-10-01 23:59:30.584443193 -0400
|
|
||||||
@@ -174,7 +174,7 @@
|
|
||||||
CYGPATH_W = @CYGPATH_W@
|
|
||||||
DEFS = @DEFS@
|
|
||||||
DEPDIR = @DEPDIR@
|
|
||||||
-DOCBOOKTOMAN = @DOCBOOKTOMAN@
|
|
||||||
+DOCBOOKTOMAN = @DOCBOOKTOMAN@ --sgml
|
|
||||||
ECHO_C = @ECHO_C@
|
|
||||||
ECHO_N = @ECHO_N@
|
|
||||||
ECHO_T = @ECHO_T@
|
|
|
@ -1,161 +0,0 @@
|
||||||
commit cf2c95edb7918bc658f6cae93793c1949fc9cb6e
|
|
||||||
Author: David Guibert <david.guibert@gmail.com>
|
|
||||||
Date: Fri Aug 5 14:20:12 2011 +0200
|
|
||||||
|
|
||||||
introduce module-dir
|
|
||||||
|
|
||||||
diff --git a/depmod.c b/depmod.c
|
|
||||||
index a1d2f8c..9362a35 100644
|
|
||||||
--- a/depmod.c
|
|
||||||
+++ b/depmod.c
|
|
||||||
@@ -48,9 +48,6 @@
|
|
||||||
|
|
||||||
#include "testing.h"
|
|
||||||
|
|
||||||
-#ifndef MODULE_DIR
|
|
||||||
-#define MODULE_DIR "/lib/modules/"
|
|
||||||
-#endif
|
|
||||||
|
|
||||||
#ifndef MODULE_BUILTIN_KEY
|
|
||||||
#define MODULE_BUILTIN_KEY "built-in"
|
|
||||||
@@ -1516,6 +1513,7 @@ static int parse_config_file(const char *filename,
|
|
||||||
char *line;
|
|
||||||
unsigned int linenum = 0;
|
|
||||||
FILE *cfile;
|
|
||||||
+ char *module_dir;
|
|
||||||
|
|
||||||
cfile = fopen(filename, "r");
|
|
||||||
if (!cfile) {
|
|
||||||
@@ -1525,6 +1523,10 @@ static int parse_config_file(const char *filename,
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
+ if((module_dir = getenv("MODULE_DIR")) == NULL) {
|
|
||||||
+ module_dir = "/lib/modules/";
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
while ((line = getline_wrapped(cfile, &linenum)) != NULL) {
|
|
||||||
char *ptr = line;
|
|
||||||
char *cmd, *modname;
|
|
||||||
@@ -1550,7 +1552,7 @@ static int parse_config_file(const char *filename,
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
nofail_asprintf(&dirname, "%s%s%s/%s", basedir,
|
|
||||||
- MODULE_DIR, kernelversion, search_path);
|
|
||||||
+ module_dir, kernelversion, search_path);
|
|
||||||
len = strlen(dirname);
|
|
||||||
*search = add_search(dirname, len, *search);
|
|
||||||
free(dirname);
|
|
||||||
@@ -1565,7 +1567,7 @@ static int parse_config_file(const char *filename,
|
|
||||||
continue;
|
|
||||||
|
|
||||||
nofail_asprintf(&pathname, "%s%s%s/%s/%s.ko", basedir,
|
|
||||||
- MODULE_DIR, kernelversion, subdir, modname);
|
|
||||||
+ module_dir, kernelversion, subdir, modname);
|
|
||||||
|
|
||||||
*overrides = add_override(pathname, *overrides);
|
|
||||||
free(pathname);
|
|
||||||
@@ -1737,6 +1739,7 @@ int main(int argc, char *argv[])
|
|
||||||
char *basedir = "", *dirname, *version;
|
|
||||||
char *system_map = NULL, *module_symvers = NULL;
|
|
||||||
int i;
|
|
||||||
+ char *module_dir;
|
|
||||||
const char *config = NULL;
|
|
||||||
|
|
||||||
if (native_endianness() == 0)
|
|
||||||
@@ -1832,7 +1835,11 @@ int main(int argc, char *argv[])
|
|
||||||
if (optind == argc)
|
|
||||||
all = 1;
|
|
||||||
|
|
||||||
- nofail_asprintf(&dirname, "%s%s%s", basedir, MODULE_DIR, version);
|
|
||||||
+ if((module_dir = getenv("MODULE_DIR")) == NULL) {
|
|
||||||
+ module_dir = "/lib/modules/";
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ nofail_asprintf(&dirname, "%s%s%s", basedir, module_dir, version);
|
|
||||||
|
|
||||||
if (maybe_all) {
|
|
||||||
if (!doing_stdout && !depfile_out_of_date(dirname))
|
|
||||||
@@ -1850,7 +1857,7 @@ int main(int argc, char *argv[])
|
|
||||||
size_t len;
|
|
||||||
|
|
||||||
nofail_asprintf(&dirname, "%s%s%s/updates", basedir,
|
|
||||||
- MODULE_DIR, version);
|
|
||||||
+ module_dir, version);
|
|
||||||
len = strlen(dirname);
|
|
||||||
search = add_search(dirname, len, search);
|
|
||||||
}
|
|
||||||
diff --git a/modinfo.c b/modinfo.c
|
|
||||||
index 1dd8469..67b1041 100644
|
|
||||||
--- a/modinfo.c
|
|
||||||
+++ b/modinfo.c
|
|
||||||
@@ -19,9 +19,6 @@
|
|
||||||
#include "zlibsupport.h"
|
|
||||||
#include "testing.h"
|
|
||||||
|
|
||||||
-#ifndef MODULE_DIR
|
|
||||||
-#define MODULE_DIR "/lib/modules"
|
|
||||||
-#endif
|
|
||||||
|
|
||||||
struct param
|
|
||||||
{
|
|
||||||
@@ -193,6 +190,11 @@ static struct elf_file *grab_module(const char *name,
|
|
||||||
struct utsname buf;
|
|
||||||
char *depname, *p, *moddir;
|
|
||||||
struct elf_file *module;
|
|
||||||
+ char *module_dir;
|
|
||||||
+
|
|
||||||
+ if((module_dir = getenv("MODULE_DIR")) == NULL) {
|
|
||||||
+ module_dir = "/lib/modules/";
|
|
||||||
+ }
|
|
||||||
|
|
||||||
if (strchr(name, '.') || strchr(name, '/')) {
|
|
||||||
module = grab_elf_file(name);
|
|
||||||
@@ -207,9 +209,9 @@ static struct elf_file *grab_module(const char *name,
|
|
||||||
kernel = buf.release;
|
|
||||||
}
|
|
||||||
if (strlen(basedir))
|
|
||||||
- nofail_asprintf(&moddir, "%s/%s/%s", basedir, MODULE_DIR, kernel);
|
|
||||||
+ nofail_asprintf(&moddir, "%s/%s/%s", basedir, module_dir, kernel);
|
|
||||||
else
|
|
||||||
- nofail_asprintf(&moddir, "%s/%s", MODULE_DIR, kernel);
|
|
||||||
+ nofail_asprintf(&moddir, "%s/%s", module_dir, kernel);
|
|
||||||
|
|
||||||
/* Search for it in modules.dep. */
|
|
||||||
nofail_asprintf(&depname, "%s/%s", moddir, "modules.dep");
|
|
||||||
diff --git a/modprobe.c b/modprobe.c
|
|
||||||
index 5464f45..d9fbf9d 100644
|
|
||||||
--- a/modprobe.c
|
|
||||||
+++ b/modprobe.c
|
|
||||||
@@ -86,10 +86,6 @@ typedef enum
|
|
||||||
|
|
||||||
} modprobe_flags_t;
|
|
||||||
|
|
||||||
-#ifndef MODULE_DIR
|
|
||||||
-#define MODULE_DIR "/lib/modules"
|
|
||||||
-#endif
|
|
||||||
-
|
|
||||||
/**
|
|
||||||
* print_usage - output the prefered program usage
|
|
||||||
*
|
|
||||||
@@ -2136,6 +2132,7 @@ int main(int argc, char *argv[])
|
|
||||||
struct modprobe_conf conf = {};
|
|
||||||
|
|
||||||
recursion_depth = 0;
|
|
||||||
+ char *module_dir = NULL;
|
|
||||||
|
|
||||||
/* Prepend options from environment. */
|
|
||||||
argv = merge_args(getenv("MODPROBE_OPTIONS"), argv, &argc);
|
|
||||||
@@ -2233,7 +2230,11 @@ int main(int argc, char *argv[])
|
|
||||||
if (argc < optind + 1 && !dump_config && !list_only)
|
|
||||||
print_usage(argv[0]);
|
|
||||||
|
|
||||||
- nofail_asprintf(&dirname, "%s%s/%s", basedir, MODULE_DIR, buf.release);
|
|
||||||
+ if((module_dir = getenv("MODULE_DIR")) == NULL) {
|
|
||||||
+ module_dir = "/lib/modules";
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ nofail_asprintf(&dirname, "%s%s/%s", basedir, module_dir, buf.release);
|
|
||||||
|
|
||||||
/* Old-style -t xxx wildcard? Only with -l. */
|
|
||||||
if (list_only) {
|
|
|
@ -1,23 +1,23 @@
|
||||||
{ stdenv, fetchurl, gperf, pkgconfig, glib, acl
|
{ stdenv, fetchurl, gperf, pkgconfig, glib, acl
|
||||||
, libusb, usbutils, pciutils }:
|
, libusb, usbutils, pciutils, libuuid, kmod }:
|
||||||
|
|
||||||
assert stdenv ? glibc;
|
assert stdenv ? glibc;
|
||||||
|
|
||||||
stdenv.mkDerivation rec {
|
stdenv.mkDerivation rec {
|
||||||
name = "udev-173";
|
name = "udev-182";
|
||||||
|
|
||||||
src = fetchurl {
|
src = fetchurl {
|
||||||
url = "mirror://kernel/linux/utils/kernel/hotplug/${name}.tar.bz2";
|
url = "mirror://kernel/linux/utils/kernel/hotplug/${name}.tar.bz2";
|
||||||
sha256 = "1bxadi4bi11v8ipzj22wknv8hsb0wgdb99bx3w9w33rgl4aq78bh";
|
sha256 = "143qvm0kij26j2l5icnch4x38fajys6li7j0c5mpwi6kqmc8hqx0";
|
||||||
};
|
};
|
||||||
|
|
||||||
buildInputs = [ gperf pkgconfig glib acl libusb usbutils ];
|
buildInputs = [ gperf pkgconfig glib acl libusb usbutils libuuid kmod ];
|
||||||
|
|
||||||
configureFlags =
|
configureFlags =
|
||||||
''
|
''
|
||||||
--with-pci-ids-path=${pciutils}/share/pci.ids
|
--with-pci-ids-path=${pciutils}/share/pci.ids
|
||||||
--enable-udev_acl --enable-edd
|
--enable-rule_generator
|
||||||
--disable-introspection --libexecdir=$(out)/lib/udev
|
--disable-introspection --libexecdir=$(out)/lib
|
||||||
--with-firmware-path=/root/test-firmware:/var/run/current-system/firmware
|
--with-firmware-path=/root/test-firmware:/var/run/current-system/firmware
|
||||||
'';
|
'';
|
||||||
|
|
||||||
|
@ -45,10 +45,6 @@ stdenv.mkDerivation rec {
|
||||||
'';
|
'';
|
||||||
|
|
||||||
patches = [ ./custom-rules.patch ] ++
|
patches = [ ./custom-rules.patch ] ++
|
||||||
[(fetchurl {
|
|
||||||
url = https://bugs.archlinux.org/task/25356?getfile=7281;
|
|
||||||
sha256 = "01xib1pfdbwacgx8dqxgrf67a0mwkpm4kxy9f9v3df93v0m4pmbm";
|
|
||||||
})] ++
|
|
||||||
stdenv.lib.optional (stdenv.system == "armv5tel-linux") ./pre-accept4-kernel.patch;
|
stdenv.lib.optional (stdenv.system == "armv5tel-linux") ./pre-accept4-kernel.patch;
|
||||||
|
|
||||||
meta = {
|
meta = {
|
|
@ -1,91 +1,40 @@
|
||||||
commit c49ec33ba0f1a7f11b188913bb4895360ced67f8
|
diff --git a/src/libudev.c b/src/libudev.c
|
||||||
Author: Yury G. Kudryashov <urkud.urkud@gmail.com>
|
index d954dae..d663160 100644
|
||||||
Date: Tue Aug 16 16:28:56 2011 +0400
|
--- a/src/libudev.c
|
||||||
|
+++ b/src/libudev.c
|
||||||
Upstream considers presence of rules_dir=... in udev.conf as a very special case.
|
@@ -229,7 +229,6 @@ UDEV_EXPORT struct udev *udev_new(void)
|
||||||
In particular, they disable /dev/.udev/*. Re-enable it.
|
}
|
||||||
|
if (strcmp(key, "udev_rules") == 0) {
|
||||||
diff --git a/udev/udev-rules.c b/udev/udev-rules.c
|
set_value(&udev->rules_path[0], val);
|
||||||
index 6bf2726..c1ae1f3 100644
|
- udev->rules_path_count = 1;
|
||||||
--- a/udev/udev-rules.c
|
continue;
|
||||||
+++ b/udev/udev-rules.c
|
}
|
||||||
@@ -1812,6 +1812,7 @@ struct udev_rules *udev_rules_new(struct udev *udev, int resolve_names)
|
}
|
||||||
struct udev_list file_list;
|
@@ -259,18 +258,18 @@ UDEV_EXPORT struct udev *udev_new(void)
|
||||||
struct udev_list_entry *file_loop;
|
udev->rules_path[0] = strdup(PKGLIBEXECDIR "/rules.d");
|
||||||
struct token end_token;
|
if (!udev->rules_path[0])
|
||||||
+ char runpathrules[UTIL_PATH_SIZE];
|
goto err;
|
||||||
|
+ }
|
||||||
|
|
||||||
rules = calloc(1, sizeof(struct udev_rules));
|
- /* /run/udev -- runtime rules */
|
||||||
if (rules == NULL)
|
- if (asprintf(&udev->rules_path[2], "%s/rules.d", udev->run_path) < 0)
|
||||||
@@ -1854,22 +1855,21 @@ struct udev_rules *udev_rules_new(struct udev *udev, int resolve_names)
|
- goto err;
|
||||||
rules->trie_nodes_cur = 1;
|
+ /* /run/udev -- runtime rules */
|
||||||
|
+ if (asprintf(&udev->rules_path[2], "%s/rules.d", udev->run_path) < 0)
|
||||||
|
+ goto err;
|
||||||
|
|
||||||
if (udev_get_rules_path(udev) == NULL) {
|
- /* /etc/udev -- local administration rules */
|
||||||
- char filename[UTIL_PATH_SIZE];
|
- udev->rules_path[1] = strdup(SYSCONFDIR "/udev/rules.d");
|
||||||
|
- if (!udev->rules_path[1])
|
||||||
|
- goto err;
|
||||||
|
+ /* /etc/udev -- local administration rules */
|
||||||
|
+ udev->rules_path[1] = strdup("/etc/udev/rules.d");
|
||||||
|
+ if (!udev->rules_path[1])
|
||||||
|
+ goto err;
|
||||||
|
|
||||||
/* /lib/udev -- default/package rules */
|
- udev->rules_path_count = 3;
|
||||||
add_matching_files(udev, &file_list, LIBEXECDIR "/rules.d", ".rules");
|
- }
|
||||||
|
+ udev->rules_path_count = 3;
|
||||||
|
|
||||||
/* /etc/udev -- system-specific/user/admin rules */
|
dbg(udev, "context %p created\n", udev);
|
||||||
add_matching_files(udev, &file_list, SYSCONFDIR "/udev/rules.d", ".rules");
|
dbg(udev, "log_priority=%d\n", udev->log_priority);
|
||||||
-
|
|
||||||
- /* /run/udev -- throw-away/temporary rules */
|
|
||||||
- util_strscpyl(filename, sizeof(filename), udev_get_run_path(udev), "/rules.d", NULL);
|
|
||||||
- add_matching_files(udev, &file_list, filename, ".rules");
|
|
||||||
} else {
|
|
||||||
/* custom rules files location for testing */
|
|
||||||
add_matching_files(udev, &file_list, udev_get_rules_path(udev), ".rules");
|
|
||||||
}
|
|
||||||
|
|
||||||
+ /* /run/udev -- throw-away/temporary rules */
|
|
||||||
+ util_strscpyl(runpathrules, sizeof(runpathrules), udev_get_run_path(udev), "/rules.d", NULL);
|
|
||||||
+ add_matching_files(udev, &file_list, runpathrules, ".rules");
|
|
||||||
+
|
|
||||||
/* add all filenames to the string buffer */
|
|
||||||
udev_list_entry_foreach(file_loop, udev_list_get_entry(&file_list)) {
|
|
||||||
const char *filename = udev_list_entry_get_value(file_loop);
|
|
||||||
diff --git a/udev/udevd.c b/udev/udevd.c
|
|
||||||
index f1a31e7..45d10b6 100644
|
|
||||||
--- a/udev/udevd.c
|
|
||||||
+++ b/udev/udevd.c
|
|
||||||
@@ -1198,6 +1198,8 @@ int main(int argc, char *argv[])
|
|
||||||
struct epoll_event ep_ctrl, ep_inotify, ep_signal, ep_netlink, ep_worker;
|
|
||||||
struct udev_ctrl_connection *ctrl_conn = NULL;
|
|
||||||
int rc = 1;
|
|
||||||
+ char filename[UTIL_PATH_SIZE];
|
|
||||||
+ struct stat statbuf;
|
|
||||||
|
|
||||||
udev = udev_new();
|
|
||||||
if (udev == NULL)
|
|
||||||
@@ -1480,23 +1482,21 @@ int main(int argc, char *argv[])
|
|
||||||
inotify_add_watch(fd_inotify, udev_get_rules_path(udev),
|
|
||||||
IN_DELETE | IN_MOVE | IN_CLOSE_WRITE);
|
|
||||||
} else {
|
|
||||||
- char filename[UTIL_PATH_SIZE];
|
|
||||||
- struct stat statbuf;
|
|
||||||
|
|
||||||
inotify_add_watch(fd_inotify, LIBEXECDIR "/rules.d",
|
|
||||||
IN_DELETE | IN_MOVE | IN_CLOSE_WRITE);
|
|
||||||
inotify_add_watch(fd_inotify, SYSCONFDIR "/udev/rules.d",
|
|
||||||
IN_DELETE | IN_MOVE | IN_CLOSE_WRITE);
|
|
||||||
+ }
|
|
||||||
|
|
||||||
- /* watch dynamic rules directory */
|
|
||||||
- util_strscpyl(filename, sizeof(filename), udev_get_run_path(udev), "/rules.d", NULL);
|
|
||||||
- if (stat(filename, &statbuf) != 0) {
|
|
||||||
- util_create_path(udev, filename);
|
|
||||||
- mkdir(filename, 0755);
|
|
||||||
- }
|
|
||||||
- inotify_add_watch(fd_inotify, filename,
|
|
||||||
- IN_DELETE | IN_MOVE | IN_CLOSE_WRITE);
|
|
||||||
+ /* watch dynamic rules directory */
|
|
||||||
+ util_strscpyl(filename, sizeof(filename), udev_get_run_path(udev), "/rules.d", NULL);
|
|
||||||
+ if (stat(filename, &statbuf) != 0) {
|
|
||||||
+ util_create_path(udev, filename);
|
|
||||||
+ mkdir(filename, 0755);
|
|
||||||
}
|
|
||||||
+ inotify_add_watch(fd_inotify, filename,
|
|
||||||
+ IN_DELETE | IN_MOVE | IN_CLOSE_WRITE);
|
|
||||||
udev_watch_restore(udev);
|
|
||||||
|
|
||||||
/* block and listen to all signals on signalfd */
|
|
||||||
|
|
|
@ -325,10 +325,9 @@ let
|
||||||
|
|
||||||
makeWrapper = makeSetupHook {} ../build-support/make-wrapper/make-wrapper.sh;
|
makeWrapper = makeSetupHook {} ../build-support/make-wrapper/make-wrapper.sh;
|
||||||
|
|
||||||
makeModulesClosure = {kernel, rootModules, allowMissing ? false}:
|
makeModulesClosure = {modulesTree, rootModules, allowMissing ? false}:
|
||||||
import ../build-support/kernel/modules-closure.nix {
|
import ../build-support/kernel/modules-closure.nix {
|
||||||
inherit stdenv module_init_tools kernel nukeReferences
|
inherit stdenv kmod modulesTree nukeReferences rootModules allowMissing;
|
||||||
rootModules allowMissing;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
pathsFromGraph = ../build-support/kernel/paths-from-graph.pl;
|
pathsFromGraph = ../build-support/kernel/paths-from-graph.pl;
|
||||||
|
@ -5832,15 +5831,15 @@ let
|
||||||
|
|
||||||
mingetty = callPackage ../os-specific/linux/mingetty { };
|
mingetty = callPackage ../os-specific/linux/mingetty { };
|
||||||
|
|
||||||
module_init_tools = callPackage ../os-specific/linux/module-init-tools { };
|
module_init_tools = pkgs.kmod;
|
||||||
|
|
||||||
mountall = callPackage ../os-specific/linux/mountall {
|
mountall = callPackage ../os-specific/linux/mountall {
|
||||||
automake = automake111x;
|
automake = automake111x;
|
||||||
};
|
};
|
||||||
|
|
||||||
aggregateModules = modules:
|
aggregateModules = modules:
|
||||||
import ../os-specific/linux/module-init-tools/aggregator.nix {
|
import ../os-specific/linux/kmod/aggregator.nix {
|
||||||
inherit stdenv module_init_tools modules buildEnv;
|
inherit stdenv kmod modules buildEnv;
|
||||||
};
|
};
|
||||||
|
|
||||||
modutils = callPackage ../os-specific/linux/modutils {
|
modutils = callPackage ../os-specific/linux/modutils {
|
||||||
|
@ -5997,8 +5996,8 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
udev145 = callPackage ../os-specific/linux/udev/145.nix { };
|
udev145 = callPackage ../os-specific/linux/udev/145.nix { };
|
||||||
udev173 = callPackage ../os-specific/linux/udev/173.nix { };
|
udev182 = callPackage ../os-specific/linux/udev/182.nix { };
|
||||||
udev = pkgs.udev173;
|
udev = pkgs.udev182;
|
||||||
|
|
||||||
udisks = callPackage ../os-specific/linux/udisks { };
|
udisks = callPackage ../os-specific/linux/udisks { };
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user