]> pere.pagekite.me Git - homepage.git/blob - blog/Using_modalias_info_to_find_packages_handling_my_hardware.html
Generated.
[homepage.git] / blog / Using_modalias_info_to_find_packages_handling_my_hardware.html
1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
2 "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
3 <html xmlns="http://www.w3.org/1999/xhtml" dir="ltr">
4 <head>
5 <meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
6 <title>Petter Reinholdtsen: Using modalias info to find packages handling my hardware</title>
7 <link rel="stylesheet" type="text/css" media="screen" href="http://people.skolelinux.org/pere/blog/style.css" />
8 <link rel="stylesheet" type="text/css" media="screen" href="http://people.skolelinux.org/pere/blog/vim.css" />
9 </head>
10 <body>
11 <div class="title">
12 <h1>
13 <a href="http://people.skolelinux.org/pere/blog/">Petter Reinholdtsen</a>
14
15 </h1>
16
17 </div>
18
19
20 <div class="entry">
21 <div class="title">Using modalias info to find packages handling my hardware</div>
22 <div class="date">15th January 2013</div>
23 <div class="body"><p>Yesterday, I wrote about the
24 <a href="http://people.skolelinux.org/pere/blog/Modalias_strings___a_practical_way_to_map__stuff__to_hardware.html">modalias
25 values provided by the Linux kernel</a> following my hope for
26 <a href="http://people.skolelinux.org/pere/blog/Lets_make_hardware_dongles_easier_to_use_in_Debian.html">better
27 dongle support in Debian</a>. Using this knowledge, I have tested how
28 modalias values attached to package names can be used to map packages
29 to hardware. This allow the system to look up and suggest relevant
30 packages when I plug in some new hardware into my machine, and replace
31 discover and discover-data as the database used to map hardware to
32 packages.</p>
33
34 <p>I create a modaliases file with entries like the following,
35 containing package name, kernel module name (if relevant, otherwise
36 the package name) and globs matching the relevant hardware
37 modalias.</p>
38
39 <p><blockquote>
40 Package: package-name
41 <br>Modaliases: module(modaliasglob, modaliasglob, modaliasglob)</p>
42 </blockquote></p>
43
44 <p>It is fairly trivial to write code to find the relevant packages
45 for a given modalias value using this file.</p>
46
47 <p>An entry like this would suggest the video and picture application
48 cheese for many USB web cameras (interface bus class 0E01):</p>
49
50 <p><blockquote>
51 Package: cheese
52 <br>Modaliases: cheese(usb:v*p*d*dc*dsc*dp*ic0Eisc01ip*)</p>
53 </blockquote></p>
54
55 <p>An entry like this would suggest the pcmciautils package when a
56 CardBus bridge (bus class 0607) PCI device is present:</p>
57
58 <p><blockquote>
59 Package: pcmciautils
60 <br>Modaliases: pcmciautils(pci:v*d*sv*sd*bc06sc07i*)
61 </blockquote></p>
62
63 <p>An entry like this would suggest the package colorhug-client when
64 plugging in a ColorHug with USB IDs 04D8:F8DA:</p>
65
66 <p><blockquote>
67 Package: colorhug-client
68 <br>Modaliases: colorhug-client(usb:v04D8pF8DAd*)</p>
69 </blockquote></p>
70
71 <p>I believe the format is compatible with the format of the Packages
72 file in the Debian archive. Ubuntu already uses their Packages file
73 to store their mappings from packages to hardware.</p>
74
75 <p>By adding a XB-Modaliases: header in debian/control, any .deb can
76 announce the hardware it support in a way my prototype understand.
77 This allow those publishing packages in an APT source outside the
78 Debian archive as well as those backporting packages to make sure the
79 hardware mapping are included in the package meta information. I've
80 tested such header in the pymissile package, and its modalias mapping
81 is working as it should with my prototype. It even made it to Ubuntu
82 Raring.</p>
83
84 <p>To test if it was possible to look up supported hardware using only
85 the shell tools available in the Debian installer, I wrote a shell
86 implementation of the lookup code. The idea is to create files for
87 each modalias and let the shell do the matching. Please check out and
88 try the
89 <a href="http://anonscm.debian.org/viewvc/debian-edu/trunk/src/hw-support-handler/hw-support-lookup?view=co">hw-support-lookup</a>
90 shell script. It run without any extra dependencies and fetch the
91 hardware mappings from the Debian archive and the subversion
92 repository where I currently work on my prototype.</p>
93
94 <p>When I use it on a machine with a yubikey inserted, it suggest to
95 install yubikey-personalization:</p>
96
97 <p><blockquote>
98 % ./hw-support-lookup
99 <br>yubikey-personalization
100 <br>%
101 </blockquote></p>
102
103 <p>When I run it on my Thinkpad X40 with a PCMCIA/CardBus slot, it
104 propose to install the pcmciautils package:</p>
105
106 <p><blockquote>
107 % ./hw-support-lookup
108 <br>pcmciautils
109 <br>%
110 </blockquote></p>
111
112 <p>If you know of any hardware-package mapping that should be added to
113 <a href="http://anonscm.debian.org/viewvc/debian-edu/trunk/src/hw-support-handler/modaliases?view=co">my
114 database</a>, please tell me about it.</p>
115
116 <p>It could be possible to generate several of the mappings between
117 packages and hardware. One source would be to look at packages with
118 kernel modules, ie packages with *.ko files in /lib/modules/, and
119 extract their modalias information. Another would be to look at
120 packages with udev rules, ie packages with files in
121 /lib/udev/rules.d/, and extract their vendor/model information to
122 generate a modalias matching rule. I have not tested any of these to
123 see if it work.</p>
124
125 <p>If you want to help implementing a system to let us propose what
126 packages to install when new hardware is plugged into a Debian
127 machine, please send me an email or talk to me on
128 <a href="irc://irc.debian.org/%23debian-devel">#debian-devel</a>.</p>
129 </div>
130
131 <div class="tags">Tags: <a href="http://people.skolelinux.org/pere/blog/tags/debian">debian</a>, <a href="http://people.skolelinux.org/pere/blog/tags/english">english</a>, <a href="http://people.skolelinux.org/pere/blog/tags/isenkram">isenkram</a>.</div>
132
133
134 </div>
135
136
137
138
139 <div id="sidebar">
140
141
142
143 <h2>Archive</h2>
144 <ul>
145
146 <li>2013
147 <ul>
148
149 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/01/">January (11)</a></li>
150
151 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/02/">February (1)</a></li>
152
153 </ul></li>
154
155 <li>2012
156 <ul>
157
158 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/01/">January (7)</a></li>
159
160 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/02/">February (10)</a></li>
161
162 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/03/">March (17)</a></li>
163
164 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/04/">April (12)</a></li>
165
166 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/05/">May (12)</a></li>
167
168 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/06/">June (20)</a></li>
169
170 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/07/">July (17)</a></li>
171
172 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/08/">August (6)</a></li>
173
174 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/09/">September (9)</a></li>
175
176 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/10/">October (17)</a></li>
177
178 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/11/">November (10)</a></li>
179
180 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/12/">December (7)</a></li>
181
182 </ul></li>
183
184 <li>2011
185 <ul>
186
187 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/01/">January (16)</a></li>
188
189 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/02/">February (6)</a></li>
190
191 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/03/">March (6)</a></li>
192
193 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/04/">April (7)</a></li>
194
195 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/05/">May (3)</a></li>
196
197 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/06/">June (2)</a></li>
198
199 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/07/">July (7)</a></li>
200
201 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/08/">August (6)</a></li>
202
203 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/09/">September (4)</a></li>
204
205 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/10/">October (2)</a></li>
206
207 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/11/">November (3)</a></li>
208
209 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/12/">December (1)</a></li>
210
211 </ul></li>
212
213 <li>2010
214 <ul>
215
216 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/01/">January (2)</a></li>
217
218 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/02/">February (1)</a></li>
219
220 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/03/">March (3)</a></li>
221
222 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/04/">April (3)</a></li>
223
224 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/05/">May (9)</a></li>
225
226 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/06/">June (14)</a></li>
227
228 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/07/">July (12)</a></li>
229
230 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/08/">August (13)</a></li>
231
232 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/09/">September (7)</a></li>
233
234 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/10/">October (9)</a></li>
235
236 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/11/">November (13)</a></li>
237
238 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/12/">December (12)</a></li>
239
240 </ul></li>
241
242 <li>2009
243 <ul>
244
245 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/01/">January (8)</a></li>
246
247 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/02/">February (8)</a></li>
248
249 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/03/">March (12)</a></li>
250
251 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/04/">April (10)</a></li>
252
253 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/05/">May (9)</a></li>
254
255 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/06/">June (3)</a></li>
256
257 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/07/">July (4)</a></li>
258
259 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/08/">August (3)</a></li>
260
261 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/09/">September (1)</a></li>
262
263 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/10/">October (2)</a></li>
264
265 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/11/">November (3)</a></li>
266
267 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/12/">December (3)</a></li>
268
269 </ul></li>
270
271 <li>2008
272 <ul>
273
274 <li><a href="http://people.skolelinux.org/pere/blog/archive/2008/11/">November (5)</a></li>
275
276 <li><a href="http://people.skolelinux.org/pere/blog/archive/2008/12/">December (7)</a></li>
277
278 </ul></li>
279
280 </ul>
281
282
283
284 <h2>Tags</h2>
285 <ul>
286
287 <li><a href="http://people.skolelinux.org/pere/blog/tags/3d-printer">3d-printer (13)</a></li>
288
289 <li><a href="http://people.skolelinux.org/pere/blog/tags/amiga">amiga (1)</a></li>
290
291 <li><a href="http://people.skolelinux.org/pere/blog/tags/aros">aros (1)</a></li>
292
293 <li><a href="http://people.skolelinux.org/pere/blog/tags/bankid">bankid (4)</a></li>
294
295 <li><a href="http://people.skolelinux.org/pere/blog/tags/bitcoin">bitcoin (6)</a></li>
296
297 <li><a href="http://people.skolelinux.org/pere/blog/tags/bootsystem">bootsystem (12)</a></li>
298
299 <li><a href="http://people.skolelinux.org/pere/blog/tags/bsa">bsa (2)</a></li>
300
301 <li><a href="http://people.skolelinux.org/pere/blog/tags/debian">debian (70)</a></li>
302
303 <li><a href="http://people.skolelinux.org/pere/blog/tags/debian edu">debian edu (118)</a></li>
304
305 <li><a href="http://people.skolelinux.org/pere/blog/tags/digistan">digistan (9)</a></li>
306
307 <li><a href="http://people.skolelinux.org/pere/blog/tags/docbook">docbook (7)</a></li>
308
309 <li><a href="http://people.skolelinux.org/pere/blog/tags/drivstoffpriser">drivstoffpriser (4)</a></li>
310
311 <li><a href="http://people.skolelinux.org/pere/blog/tags/english">english (176)</a></li>
312
313 <li><a href="http://people.skolelinux.org/pere/blog/tags/fiksgatami">fiksgatami (21)</a></li>
314
315 <li><a href="http://people.skolelinux.org/pere/blog/tags/fildeling">fildeling (12)</a></li>
316
317 <li><a href="http://people.skolelinux.org/pere/blog/tags/freeculture">freeculture (10)</a></li>
318
319 <li><a href="http://people.skolelinux.org/pere/blog/tags/frikanalen">frikanalen (9)</a></li>
320
321 <li><a href="http://people.skolelinux.org/pere/blog/tags/intervju">intervju (32)</a></li>
322
323 <li><a href="http://people.skolelinux.org/pere/blog/tags/isenkram">isenkram (5)</a></li>
324
325 <li><a href="http://people.skolelinux.org/pere/blog/tags/kart">kart (17)</a></li>
326
327 <li><a href="http://people.skolelinux.org/pere/blog/tags/ldap">ldap (8)</a></li>
328
329 <li><a href="http://people.skolelinux.org/pere/blog/tags/lenker">lenker (6)</a></li>
330
331 <li><a href="http://people.skolelinux.org/pere/blog/tags/ltsp">ltsp (1)</a></li>
332
333 <li><a href="http://people.skolelinux.org/pere/blog/tags/multimedia">multimedia (25)</a></li>
334
335 <li><a href="http://people.skolelinux.org/pere/blog/tags/norsk">norsk (219)</a></li>
336
337 <li><a href="http://people.skolelinux.org/pere/blog/tags/nuug">nuug (148)</a></li>
338
339 <li><a href="http://people.skolelinux.org/pere/blog/tags/offentlig innsyn">offentlig innsyn (6)</a></li>
340
341 <li><a href="http://people.skolelinux.org/pere/blog/tags/open311">open311 (2)</a></li>
342
343 <li><a href="http://people.skolelinux.org/pere/blog/tags/opphavsrett">opphavsrett (41)</a></li>
344
345 <li><a href="http://people.skolelinux.org/pere/blog/tags/personvern">personvern (61)</a></li>
346
347 <li><a href="http://people.skolelinux.org/pere/blog/tags/raid">raid (1)</a></li>
348
349 <li><a href="http://people.skolelinux.org/pere/blog/tags/reprap">reprap (11)</a></li>
350
351 <li><a href="http://people.skolelinux.org/pere/blog/tags/rfid">rfid (2)</a></li>
352
353 <li><a href="http://people.skolelinux.org/pere/blog/tags/robot">robot (6)</a></li>
354
355 <li><a href="http://people.skolelinux.org/pere/blog/tags/rss">rss (1)</a></li>
356
357 <li><a href="http://people.skolelinux.org/pere/blog/tags/ruter">ruter (4)</a></li>
358
359 <li><a href="http://people.skolelinux.org/pere/blog/tags/scraperwiki">scraperwiki (2)</a></li>
360
361 <li><a href="http://people.skolelinux.org/pere/blog/tags/sikkerhet">sikkerhet (28)</a></li>
362
363 <li><a href="http://people.skolelinux.org/pere/blog/tags/sitesummary">sitesummary (4)</a></li>
364
365 <li><a href="http://people.skolelinux.org/pere/blog/tags/skepsis">skepsis (4)</a></li>
366
367 <li><a href="http://people.skolelinux.org/pere/blog/tags/standard">standard (39)</a></li>
368
369 <li><a href="http://people.skolelinux.org/pere/blog/tags/stavekontroll">stavekontroll (3)</a></li>
370
371 <li><a href="http://people.skolelinux.org/pere/blog/tags/stortinget">stortinget (5)</a></li>
372
373 <li><a href="http://people.skolelinux.org/pere/blog/tags/surveillance">surveillance (12)</a></li>
374
375 <li><a href="http://people.skolelinux.org/pere/blog/tags/sysadmin">sysadmin (1)</a></li>
376
377 <li><a href="http://people.skolelinux.org/pere/blog/tags/valg">valg (7)</a></li>
378
379 <li><a href="http://people.skolelinux.org/pere/blog/tags/video">video (35)</a></li>
380
381 <li><a href="http://people.skolelinux.org/pere/blog/tags/vitenskap">vitenskap (4)</a></li>
382
383 <li><a href="http://people.skolelinux.org/pere/blog/tags/web">web (26)</a></li>
384
385 </ul>
386
387
388 </div>
389 <p style="text-align: right">
390 Created by <a href="http://steve.org.uk/Software/chronicle">Chronicle v4.4</a>
391 </p>
392
393 </body>
394 </html>