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