]> www.opopop.net Git - reminder/blob - Debian_Jessie_with_eudev_instead_of_udev_from_systemd.mdwn
54ddbb821bd0432fc4b5254c4c8ab3c4489dd601
[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 reducing 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 [[eudev_3.2.5-1bu1.dsc]]
28
29 [[eudev_3.2.5.orig.tar.gz]]
30
31 [[eudev_3.2.5-1bu1.debian.tar.xz]]
32
33 [[eudev_3.2.5-1bu1_i386.changes]]
34
35 [[libeudev1_3.2.5-1bu1_i386.deb]]
36
37 [[eudev_3.2.5-1bu1_i386.deb]]
38
39 If you have installed the needed development packages, it's easy to
40 rebuild files "libeudev1_3.2.5-1bu1_i386.deb" and
41 "eudev_3.2.5-1bu1_i386.deb" with these simple commands:
42
43     # the 3 source files have to be downloaded in your current working directory
44     dpkg-source -x eudev_3.2.5-1bu1.dsc
45     cd eudev-3.2.5
46     dpkg-buildpackage -rfakeroot
47     cd ..
48
49 Notice that .udev packages and a development package of libeudev1 are also
50 generated in the process.
51
52 To install the two packages, you will need some local package repository. An easy
53 method to do it is to run:
54
55     mkdir -p ~/my-repo/dists/jessie/main/binary-i386
56     mv libeudev1_3.2.5-1bu1_i386.deb eudev_3.2.5-1bu1_i386.deb ~/my-repo/
57     dpkg-scanpackages ~/my-repo /dev/null | gzip > ~/my-repo/dists/jessie/main/binary-i386/Packages.gz
58
59 Notice that "dpkg-scanpackages" is available through package
60 *dpkg-dev*.
61
62 Then add line (if you are user "joe"):
63
64     deb file:/home/joe/my-repo/ jessie main 
65
66 to /etc/apt/sources.list and update the available packages in aptitude
67 to take the content of your local repository into account.
68
69 You can then try to upgrade to the new *eudev* and *libeudev* with
70 aptitude. You will get a conflict. Choose to solve it by suppressing
71 *udev* and *libudev*, proceed with the upgrade and you are done! There
72 will be some warnings during the installation because we are playing
73 hard with the package versioning system, but they are harmless.
74
75 ## Final remarks
76
77 It should be obvious, but the process above is intended for a Jessie
78 installation without systemd as the init process, as the one described 
79 [here](http://www.opopop.net/Avoid_systemd_on_Debian_Jessie_with_Mate/). 
80 Actually it has only be tested in that framework.
81
82 The only issue encountered was about firmare loading. The Jessie
83 kernel 3.16 handles radeon uvd in a way which makes me loose
84 resume/suspend. So I suppressed the needed firmware file. This
85 triggers a futile attempt (because the file is not there) at
86 user-space firmware loading. But with *eudev*, which lacks user-space
87 firmware loading, this leads to a 60s delay in the boot process.
88
89 I will not add user-space firmware loading to *eudev*, as it is
90 considered obsolete by the kernel people. Instead, you can either:
91
92 1. Reduce the 60s delay by inserting for instance before the 'udevadm settle' command in /etc/init.d/eudev:
93     echo 5 > /lib/class/firmware/timeout
94
95 2. Upgrade to a better radeon driver, for instance the one of kernel
96 4.9 from jessie-backport
97
98 I have finally chosen solution 2).