]> www.opopop.net Git - reminder/blob - Debian_Jessie_with_eudev_instead_of_udev_from_systemd.mdwn
(no commit message)
[reminder] / Debian_Jessie_with_eudev_instead_of_udev_from_systemd.mdwn
1 ## Introduction
2
3 At the end of that previous page [Avoid systemd on Debian Jessie with
4 Mate](http://www.opopop.net/Avoid_systemd_on_Debian_Jessie_with_Mate/),
5 I noticed that eliminating *systemd* won't be fully accomplished
6 without also using an alternative to *udev*.
7
8 I will show here that it is possible to use  [*eudev*](https://wiki.gentoo.org/wiki/Eudev)
9 to reach that goal. *eudev* has been packaged
10 for the latest Devuan distribution, see that
11 [announcement](https://dev1galaxy.org/viewtopic.php?id=1888). So it
12 should be easy to port that for straight Debian.
13
14 ## Modification to source code
15
16 I started with source code version 3.2.5-1 from the latest Devuan. The
17 goal is to obtain a smooth upgrade from the *udev* and *libudev*
18 packages in Jessie (as it is what I am using). To ensure that, the new
19 packages will provide the old names.
20
21 My modifications were aimed at redusing the number of dependencies of the packages
22 and to correct the Devuanisms present in the installation/removal scripts.
23
24 For your convenience, all of the source files and the .deb packages
25 (for i386) are here:
26
27 If you have installed the needed development packages, it's easy to
28 rebuild files "libeudev1_3.2.5-1bu1_i386.deb" and
29 "eudev_3.2.5-1bu1_i386.deb" with these simple commands:
30
31     # the 4 source files have to be downloaded in your current working directory
32     dpkg-source -x eudev_3.2.5-1bu1.dsc
33     cd eudev-3.2.5
34     dpkg-buildpackage -rfakeroot
35     cd ..
36
37 Notice that .udev packages and a development package of libeudev1 are also
38 generated in the process.
39
40 To install the two packages, you will need some local package repository. An easy
41 method to do it is to run:
42
43     mkdir -p ~/my-repo/dists/jessie/main/binary-i386
44     mv libeudev1_3.2.5-1bu1_i386.deb eudev_3.2.5-1bu1_i386.deb ~/my-repo/
45     dpkg-scanpackages ~/my-repo /dev/null | gzip > ~/my-repo/dists/jessie/main/binary-i386/Packages.gz
46
47 Notice that "dpkg-scanpackages" is available through package
48 *dpkg-dev*.
49
50 Then add line (if you are user "joe"):
51
52     deb file:/home/joe/my-repo/ jessie main 
53
54 to /etc/apt/sources.list and update the available packages in aptitude
55 to take the content of your local repository into account.
56
57 You can then try to upgrade to the new *eudev* and *libeudev* with
58 aptitude. You will get a conflict. Choose to solve it by suppressing
59 *udev* and *libudev*, proceed with the upgrade and you are done! There
60 will be some warnings during the installation because we are playing
61 hard with the package versioning system, but they are harmless.
62
63 ## Final remarks
64
65 It should be obvious, but the process above is intended for a Jessie
66 installation without systemd as the init process, as the one described 
67 [here](http://www.opopop.net/Avoid_systemd_on_Debian_Jessie_with_Mate/). 
68 Actually it has only be tested in that framework.
69
70 The only issue encountered was about firmare loading. The Jessie
71 kernel 3.16 handles radeon uvd in a way which makes me loose
72 resume/suspend. So I suppressed the needed firmware file. This
73 triggers a futile attempt (because the file is not there) at
74 user-space firmware loading. But with *eudev*, which lacks user-space
75 firmware loading, this leads to a 60s delay in the boot process.
76
77 I will not add user-space firmware loading to *eudev*, as it is
78 considered obsolete by the kernel people. Instead, you can either:
79
80 1) reduce the 60s delay by inserting for instance:
81
82     echo 5 > /lib/class/firmware/timeout
83
84 before the 'udevadm settle' command in /etc/init.d/eudev
85
86 2) upgrade to a better radeon driver, for instance the one of kernel
87 4.9 from jessie-backport
88
89 I have finally chosen solution 2).