X-Git-Url: https://pere.pagekite.me/gitweb/homepage.git/blobdiff_plain/c4148ec5c3348581ea01db09deec4efd1549aecd..e80fd8769bcfb907ce5fa2597022b496eb658342:/blog/archive/2014/04/04.rss diff --git a/blog/archive/2014/04/04.rss b/blog/archive/2014/04/04.rss index e41c34d999..9ae8ecaa23 100644 --- a/blog/archive/2014/04/04.rss +++ b/blog/archive/2014/04/04.rss @@ -6,6 +6,95 @@ http://people.skolelinux.org/pere/blog/ + + Install hardware dependent packages using tasksel (Isenkram 0.7) + http://people.skolelinux.org/pere/blog/Install_hardware_dependent_packages_using_tasksel__Isenkram_0_7_.html + http://people.skolelinux.org/pere/blog/Install_hardware_dependent_packages_using_tasksel__Isenkram_0_7_.html + Wed, 23 Apr 2014 14:50:00 +0200 + <p>It would be nice if it was easier in Debian to get all the hardware +related packages relevant for the computer installed automatically. +So I implemented one, using +<a href="http://packages.qa.debian.org/isenkram">my Isenkram +package</a>. To use it, install the tasksel and isenkram packages and +run tasksel as user root. You should be presented with a new option, +"Hardware specific packages (autodetected by isenkram)". When you +select it, tasksel will install the packages isenkram claim is fit for +the current hardware, hot pluggable or not.<p> + +<p>The implementation is in two files, one is the tasksel menu entry +description, and the other is the script used to extract the list of +packages to install. The first part is in +<tt>/usr/share/tasksel/descs/isenkram.desc</tt> and look like +this:</p> + +<p><blockquote><pre> +Task: isenkram +Section: hardware +Description: Hardware specific packages (autodetected by isenkram) + Based on the detected hardware various hardware specific packages are + proposed. +Test-new-install: mark show +Relevance: 8 +Packages: for-current-hardware +</pre></blockquote></p> + +<p>The second part is in +<tt>/usr/lib/tasksel/packages/for-current-hardware</tt> and look like +this:</p> + +<p><blockquote><pre> +#!/bin/sh +# +( + isenkram-lookup + isenkram-autoinstall-firmware -l +) | sort -u +</pre></blockquote></p> + +<p>All in all, a very short and simple implementation making it +trivial to install the hardware dependent package we all may want to +have installed on our machines. I've not been able to find a way to +get tasksel to tell you exactly which packages it plan to install +before doing the installation. So if you are curious or careful, +check the output from the isenkram-* command line tools first.</p> + +<p>The information about which packages are handling which hardware is +fetched either from the isenkram package itself in +/usr/share/isenkram/, from git.debian.org or from the APT package +database (using the Modaliases header). The APT package database +parsing have caused a nasty resource leak in the isenkram daemon (bugs +<a href="http://bugs.debian.org/719837">#719837</a> and +<a href="http://bugs.debian.org/730704">#730704</a>). The cause is in +the python-apt code (bug +<a href="http://bugs.debian.org/745487">#745487</a>), but using a +workaround I was able to get rid of the file descriptor leak and +reduce the memory leak from ~30 MiB per hardware detection down to +around 2 miB per hardware detection. It should make the desktop +daemon a lot more useful. The fix is in version 0.7 uploaded to +unstable today.</p> + +<p>I believe the current way of mapping hardware to packages in +Isenkram is is a good draft, but in the future I expect isenkram to +use the AppStream data source for this. A proposal for getting proper +AppStream support into Debian is floating around as +<a href="https://wiki.debian.org/DEP-11">DEP-11</a>, and +<a href="https://wiki.debian.org/SummerOfCode2014/Projects#SummerOfCode2014.2FProjects.2FAppStreamDEP11Implementation.AppStream.2FDEP-11_for_the_Debian_Archive">GSoC +project</a> will take place this summer to improve the situation. I +look forward to seeing the result, and welcome patches for isenkram to +start using the information when it is ready.</p> + +<p>If you want your package to map to some specific hardware, either +add a "Xb-Modaliases" header to your control file like I did in +<a href="http://packages.qa.debian.org/pymissile">the pymissile +package</a> or submit a bug report with the details to the isenkram +package. See also +<a href="http://people.skolelinux.org/pere/blog/tags/isenkram/">all my +blog posts tagged isenkram</a> for details on the notation. I expect +the information will be migrated to AppStream eventually, but for the +moment I got no better place to store it.</p> + + + FreedomBox milestone - all packages now in Debian Sid http://people.skolelinux.org/pere/blog/FreedomBox_milestone___all_packages_now_in_Debian_Sid.html