2007-07-22 02:07:02 +00:00
|
|
|
{ stdenv, writeText, substituteAll, cleanSource, udev, procps, firmwareDirs
|
|
|
|
, extraUdevPkgs ? []
|
2008-01-02 10:07:52 +00:00
|
|
|
, sndMode ? "0600"
|
2007-07-22 02:07:02 +00:00
|
|
|
}:
|
2006-12-13 14:24:33 +00:00
|
|
|
|
|
|
|
let
|
|
|
|
|
2007-03-03 23:20:08 +00:00
|
|
|
# Perform substitutions in all udev rules files.
|
|
|
|
udevRules = stdenv.mkDerivation {
|
|
|
|
name = "udev-rules";
|
|
|
|
src = cleanSource ./udev-rules;
|
|
|
|
firmwareLoader = substituteAll {
|
|
|
|
src = ./udev-firmware-loader.sh;
|
|
|
|
path = "${stdenv.coreutils}/bin";
|
|
|
|
isExecutable = true;
|
|
|
|
inherit firmwareDirs;
|
|
|
|
};
|
2008-01-02 10:07:52 +00:00
|
|
|
inherit sndMode;
|
2007-03-03 23:20:08 +00:00
|
|
|
buildCommand = "
|
|
|
|
buildCommand= # urgh
|
|
|
|
ensureDir $out
|
|
|
|
for i in $src/*; do
|
|
|
|
substituteAll $i $out/$(basename $i)
|
|
|
|
done
|
2007-07-22 02:07:02 +00:00
|
|
|
shopt -s nullglob
|
|
|
|
for i in ${toString extraUdevPkgs}; do
|
|
|
|
for j in $i/etc/udev/rules.d/*; do
|
|
|
|
ln -s $j $out/$(basename $j)
|
|
|
|
done
|
|
|
|
done
|
2007-03-03 23:20:08 +00:00
|
|
|
";
|
|
|
|
};
|
|
|
|
|
|
|
|
# The udev configuration file
|
2008-02-04 10:52:58 +00:00
|
|
|
conf = writeText "udev.conf" ''
|
|
|
|
udev_rules="${udevRules}"
|
|
|
|
#udev_log="debug"
|
|
|
|
'';
|
2006-12-13 14:24:33 +00:00
|
|
|
|
2007-04-02 15:00:31 +00:00
|
|
|
# Dummy file indicating whether we've run udevtrigger/udevsettle.
|
|
|
|
# Since that *recreates* all device nodes with default permissions,
|
|
|
|
# it's not nice to do that when a user is logged in (it messes up
|
|
|
|
# the permissions set by pam_devperm).
|
|
|
|
# !!! Actually, this makes the udev configuration less declarative;
|
|
|
|
# changes may not take effect until the user reboots. We should
|
|
|
|
# find a better way to preserve the permissions of logged-in users.
|
|
|
|
devicesCreated = "/var/run/devices-created";
|
|
|
|
|
2006-12-13 14:24:33 +00:00
|
|
|
in
|
2006-12-13 12:17:38 +00:00
|
|
|
|
|
|
|
{
|
|
|
|
name = "udev";
|
|
|
|
|
|
|
|
job = "
|
|
|
|
start on startup
|
|
|
|
stop on shutdown
|
|
|
|
|
2006-12-13 14:24:33 +00:00
|
|
|
env UDEV_CONFIG_FILE=${conf}
|
|
|
|
|
2006-12-13 12:17:38 +00:00
|
|
|
start script
|
|
|
|
echo '' > /proc/sys/kernel/hotplug
|
|
|
|
|
2006-12-21 20:07:46 +00:00
|
|
|
# Get rid of possible old udev processes.
|
|
|
|
${procps}/bin/pkill -u root '^udevd$' || true
|
|
|
|
|
2006-12-13 12:17:38 +00:00
|
|
|
# Start udev.
|
|
|
|
${udev}/sbin/udevd --daemon
|
|
|
|
|
|
|
|
# Let udev create device nodes for all modules that have already
|
|
|
|
# been loaded into the kernel (or for which support is built into
|
|
|
|
# the kernel).
|
2007-04-02 15:00:31 +00:00
|
|
|
if ! test -e ${devicesCreated}; then
|
|
|
|
${udev}/sbin/udevtrigger
|
|
|
|
${udev}/sbin/udevsettle # wait for udev to finish
|
|
|
|
touch ${devicesCreated}
|
|
|
|
fi
|
2006-12-13 12:17:38 +00:00
|
|
|
|
|
|
|
# Kill udev, let Upstart restart and monitor it. (This is nasty,
|
|
|
|
# but we have to run udevtrigger first. Maybe we can use
|
|
|
|
# Upstart's `binary' keyword, but it isn't implemented yet.)
|
2006-12-21 20:07:46 +00:00
|
|
|
if ! ${procps}/bin/pkill -u root '^udevd$'; then
|
2006-12-16 21:48:12 +00:00
|
|
|
echo \"couldn't stop udevd\"
|
|
|
|
fi
|
2006-12-21 18:09:10 +00:00
|
|
|
|
2006-12-21 20:07:46 +00:00
|
|
|
while ${procps}/bin/pgrep -u root '^udevd$'; do
|
|
|
|
sleep 1
|
|
|
|
done
|
|
|
|
|
2006-12-21 18:09:10 +00:00
|
|
|
initctl emit new-devices
|
2006-12-13 12:17:38 +00:00
|
|
|
end script
|
|
|
|
|
|
|
|
respawn ${udev}/sbin/udevd
|
|
|
|
";
|
|
|
|
|
|
|
|
}
|