aboutsummaryrefslogtreecommitdiffstats
path: root/scripts/mod/file2alias.c
diff options
context:
space:
mode:
Diffstat (limited to 'scripts/mod/file2alias.c')
-rw-r--r--scripts/mod/file2alias.c105
1 files changed, 83 insertions, 22 deletions
diff --git a/scripts/mod/file2alias.c b/scripts/mod/file2alias.c
index 348d8687b7c9..cea4a790e1e9 100644
--- a/scripts/mod/file2alias.c
+++ b/scripts/mod/file2alias.c
@@ -51,6 +51,15 @@ do { \
51 sprintf(str + strlen(str), "*"); \ 51 sprintf(str + strlen(str), "*"); \
52} while(0) 52} while(0)
53 53
54/* Always end in a wildcard, for future extension */
55static inline void add_wildcard(char *str)
56{
57 int len = strlen(str);
58
59 if (str[len - 1] != '*')
60 strcat(str + len, "*");
61}
62
54unsigned int cross_build = 0; 63unsigned int cross_build = 0;
55/** 64/**
56 * Check that sizeof(device_id type) are consistent with size of section 65 * Check that sizeof(device_id type) are consistent with size of section
@@ -133,9 +142,7 @@ static void do_usb_entry(struct usb_device_id *id,
133 id->match_flags&USB_DEVICE_ID_MATCH_INT_PROTOCOL, 142 id->match_flags&USB_DEVICE_ID_MATCH_INT_PROTOCOL,
134 id->bInterfaceProtocol); 143 id->bInterfaceProtocol);
135 144
136 /* Always end in a wildcard, for future extension */ 145 add_wildcard(alias);
137 if (alias[strlen(alias)-1] != '*')
138 strcat(alias, "*");
139 buf_printf(&mod->dev_table_buf, 146 buf_printf(&mod->dev_table_buf,
140 "MODULE_ALIAS(\"%s\");\n", alias); 147 "MODULE_ALIAS(\"%s\");\n", alias);
141} 148}
@@ -219,6 +226,7 @@ static int do_ieee1394_entry(const char *filename,
219 ADD(alias, "ver", id->match_flags & IEEE1394_MATCH_VERSION, 226 ADD(alias, "ver", id->match_flags & IEEE1394_MATCH_VERSION,
220 id->version); 227 id->version);
221 228
229 add_wildcard(alias);
222 return 1; 230 return 1;
223} 231}
224 232
@@ -261,6 +269,7 @@ static int do_pci_entry(const char *filename,
261 ADD(alias, "bc", baseclass_mask == 0xFF, baseclass); 269 ADD(alias, "bc", baseclass_mask == 0xFF, baseclass);
262 ADD(alias, "sc", subclass_mask == 0xFF, subclass); 270 ADD(alias, "sc", subclass_mask == 0xFF, subclass);
263 ADD(alias, "i", interface_mask == 0xFF, interface); 271 ADD(alias, "i", interface_mask == 0xFF, interface);
272 add_wildcard(alias);
264 return 1; 273 return 1;
265} 274}
266 275
@@ -283,6 +292,7 @@ static int do_ccw_entry(const char *filename,
283 id->dev_type); 292 id->dev_type);
284 ADD(alias, "dm", id->match_flags&CCW_DEVICE_ID_MATCH_DEVICE_MODEL, 293 ADD(alias, "dm", id->match_flags&CCW_DEVICE_ID_MATCH_DEVICE_MODEL,
285 id->dev_model); 294 id->dev_model);
295 add_wildcard(alias);
286 return 1; 296 return 1;
287} 297}
288 298
@@ -290,7 +300,7 @@ static int do_ccw_entry(const char *filename,
290static int do_ap_entry(const char *filename, 300static int do_ap_entry(const char *filename,
291 struct ap_device_id *id, char *alias) 301 struct ap_device_id *id, char *alias)
292{ 302{
293 sprintf(alias, "ap:t%02X", id->dev_type); 303 sprintf(alias, "ap:t%02X*", id->dev_type);
294 return 1; 304 return 1;
295} 305}
296 306
@@ -309,6 +319,7 @@ static int do_serio_entry(const char *filename,
309 ADD(alias, "id", id->id != SERIO_ANY, id->id); 319 ADD(alias, "id", id->id != SERIO_ANY, id->id);
310 ADD(alias, "ex", id->extra != SERIO_ANY, id->extra); 320 ADD(alias, "ex", id->extra != SERIO_ANY, id->extra);
311 321
322 add_wildcard(alias);
312 return 1; 323 return 1;
313} 324}
314 325
@@ -316,7 +327,7 @@ static int do_serio_entry(const char *filename,
316static int do_acpi_entry(const char *filename, 327static int do_acpi_entry(const char *filename,
317 struct acpi_device_id *id, char *alias) 328 struct acpi_device_id *id, char *alias)
318{ 329{
319 sprintf(alias, "acpi*:%s:", id->id); 330 sprintf(alias, "acpi*:%s:*", id->id);
320 return 1; 331 return 1;
321} 332}
322 333
@@ -324,23 +335,56 @@ static int do_acpi_entry(const char *filename,
324static int do_pnp_entry(const char *filename, 335static int do_pnp_entry(const char *filename,
325 struct pnp_device_id *id, char *alias) 336 struct pnp_device_id *id, char *alias)
326{ 337{
327 sprintf(alias, "pnp:d%s", id->id); 338 sprintf(alias, "pnp:d%s*", id->id);
328 return 1; 339 return 1;
329} 340}
330 341
331/* looks like: "pnp:cCdD..." */ 342/* looks like: "pnp:dD" for every device of the card */
332static int do_pnp_card_entry(const char *filename, 343static void do_pnp_card_entries(void *symval, unsigned long size,
333 struct pnp_card_device_id *id, char *alias) 344 struct module *mod)
334{ 345{
335 int i; 346 const unsigned long id_size = sizeof(struct pnp_card_device_id);
347 const unsigned int count = (size / id_size)-1;
348 const struct pnp_card_device_id *cards = symval;
349 unsigned int i;
336 350
337 sprintf(alias, "pnp:c%s", id->id); 351 device_id_check(mod->name, "pnp", size, id_size, symval);
338 for (i = 0; i < PNP_MAX_DEVICES; i++) { 352
339 if (! *id->devs[i].id) 353 for (i = 0; i < count; i++) {
340 break; 354 unsigned int j;
341 sprintf(alias + strlen(alias), "d%s", id->devs[i].id); 355 const struct pnp_card_device_id *card = &cards[i];
356
357 for (j = 0; j < PNP_MAX_DEVICES; j++) {
358 const char *id = (char *)card->devs[j].id;
359 int i2, j2;
360 int dup = 0;
361
362 if (!id[0])
363 break;
364
365 /* find duplicate, already added value */
366 for (i2 = 0; i2 < i && !dup; i2++) {
367 const struct pnp_card_device_id *card2 = &cards[i2];
368
369 for (j2 = 0; j2 < PNP_MAX_DEVICES; j2++) {
370 const char *id2 = (char *)card2->devs[j2].id;
371
372 if (!id2[0])
373 break;
374
375 if (!strcmp(id, id2)) {
376 dup = 1;
377 break;
378 }
379 }
380 }
381
382 /* add an individual alias for every device entry */
383 if (!dup)
384 buf_printf(&mod->dev_table_buf,
385 "MODULE_ALIAS(\"pnp:d%s*\");\n", id);
386 }
342 } 387 }
343 return 1;
344} 388}
345 389
346/* Looks like: pcmcia:mNcNfNfnNpfnNvaNvbNvcNvdN. */ 390/* Looks like: pcmcia:mNcNfNfnNpfnNvaNvbNvcNvdN. */
@@ -376,6 +420,7 @@ static int do_pcmcia_entry(const char *filename,
376 ADD(alias, "pc", id->match_flags & PCMCIA_DEV_ID_MATCH_PROD_ID3, id->prod_id_hash[2]); 420 ADD(alias, "pc", id->match_flags & PCMCIA_DEV_ID_MATCH_PROD_ID3, id->prod_id_hash[2]);
377 ADD(alias, "pd", id->match_flags & PCMCIA_DEV_ID_MATCH_PROD_ID4, id->prod_id_hash[3]); 421 ADD(alias, "pd", id->match_flags & PCMCIA_DEV_ID_MATCH_PROD_ID4, id->prod_id_hash[3]);
378 422
423 add_wildcard(alias);
379 return 1; 424 return 1;
380} 425}
381 426
@@ -399,6 +444,7 @@ static int do_of_entry (const char *filename, struct of_device_id *of, char *ali
399 if (isspace (*tmp)) 444 if (isspace (*tmp))
400 *tmp = '_'; 445 *tmp = '_';
401 446
447 add_wildcard(alias);
402 return 1; 448 return 1;
403} 449}
404 450
@@ -415,6 +461,7 @@ static int do_vio_entry(const char *filename, struct vio_device_id *vio,
415 if (isspace (*tmp)) 461 if (isspace (*tmp))
416 *tmp = '_'; 462 *tmp = '_';
417 463
464 add_wildcard(alias);
418 return 1; 465 return 1;
419} 466}
420 467
@@ -478,6 +525,8 @@ static int do_eisa_entry(const char *filename, struct eisa_device_id *eisa,
478{ 525{
479 if (eisa->sig[0]) 526 if (eisa->sig[0])
480 sprintf(alias, EISA_DEVICE_MODALIAS_FMT "*", eisa->sig); 527 sprintf(alias, EISA_DEVICE_MODALIAS_FMT "*", eisa->sig);
528 else
529 strcat(alias, "*");
481 return 1; 530 return 1;
482} 531}
483 532
@@ -496,6 +545,7 @@ static int do_parisc_entry(const char *filename, struct parisc_device_id *id,
496 ADD(alias, "rev", id->hversion_rev != PA_HVERSION_REV_ANY_ID, id->hversion_rev); 545 ADD(alias, "rev", id->hversion_rev != PA_HVERSION_REV_ANY_ID, id->hversion_rev);
497 ADD(alias, "sv", id->sversion != PA_SVERSION_ANY_ID, id->sversion); 546 ADD(alias, "sv", id->sversion != PA_SVERSION_ANY_ID, id->sversion);
498 547
548 add_wildcard(alias);
499 return 1; 549 return 1;
500} 550}
501 551
@@ -511,6 +561,7 @@ static int do_sdio_entry(const char *filename,
511 ADD(alias, "c", id->class != (__u8)SDIO_ANY_ID, id->class); 561 ADD(alias, "c", id->class != (__u8)SDIO_ANY_ID, id->class);
512 ADD(alias, "v", id->vendor != (__u16)SDIO_ANY_ID, id->vendor); 562 ADD(alias, "v", id->vendor != (__u16)SDIO_ANY_ID, id->vendor);
513 ADD(alias, "d", id->device != (__u16)SDIO_ANY_ID, id->device); 563 ADD(alias, "d", id->device != (__u16)SDIO_ANY_ID, id->device);
564 add_wildcard(alias);
514 return 1; 565 return 1;
515} 566}
516 567
@@ -526,6 +577,7 @@ static int do_ssb_entry(const char *filename,
526 ADD(alias, "v", id->vendor != SSB_ANY_VENDOR, id->vendor); 577 ADD(alias, "v", id->vendor != SSB_ANY_VENDOR, id->vendor);
527 ADD(alias, "id", id->coreid != SSB_ANY_ID, id->coreid); 578 ADD(alias, "id", id->coreid != SSB_ANY_ID, id->coreid);
528 ADD(alias, "rev", id->revision != SSB_ANY_REV, id->revision); 579 ADD(alias, "rev", id->revision != SSB_ANY_REV, id->revision);
580 add_wildcard(alias);
529 return 1; 581 return 1;
530} 582}
531 583
@@ -540,6 +592,16 @@ static int do_virtio_entry(const char *filename, struct virtio_device_id *id,
540 ADD(alias, "d", 1, id->device); 592 ADD(alias, "d", 1, id->device);
541 ADD(alias, "v", id->vendor != VIRTIO_DEV_ANY_ID, id->vendor); 593 ADD(alias, "v", id->vendor != VIRTIO_DEV_ANY_ID, id->vendor);
542 594
595 add_wildcard(alias);
596 return 1;
597}
598
599/* Looks like: i2c:S */
600static int do_i2c_entry(const char *filename, struct i2c_device_id *id,
601 char *alias)
602{
603 sprintf(alias, I2C_MODULE_PREFIX "%s", id->name);
604
543 return 1; 605 return 1;
544} 606}
545 607
@@ -570,9 +632,6 @@ static void do_table(void *symval, unsigned long size,
570 632
571 for (i = 0; i < size; i += id_size) { 633 for (i = 0; i < size; i += id_size) {
572 if (do_entry(mod->name, symval+i, alias)) { 634 if (do_entry(mod->name, symval+i, alias)) {
573 /* Always end in a wildcard, for future extension */
574 if (alias[strlen(alias)-1] != '*')
575 strcat(alias, "*");
576 buf_printf(&mod->dev_table_buf, 635 buf_printf(&mod->dev_table_buf,
577 "MODULE_ALIAS(\"%s\");\n", alias); 636 "MODULE_ALIAS(\"%s\");\n", alias);
578 } 637 }
@@ -634,9 +693,7 @@ void handle_moddevtable(struct module *mod, struct elf_info *info,
634 sizeof(struct pnp_device_id), "pnp", 693 sizeof(struct pnp_device_id), "pnp",
635 do_pnp_entry, mod); 694 do_pnp_entry, mod);
636 else if (sym_is(symname, "__mod_pnp_card_device_table")) 695 else if (sym_is(symname, "__mod_pnp_card_device_table"))
637 do_table(symval, sym->st_size, 696 do_pnp_card_entries(symval, sym->st_size, mod);
638 sizeof(struct pnp_card_device_id), "pnp_card",
639 do_pnp_card_entry, mod);
640 else if (sym_is(symname, "__mod_pcmcia_device_table")) 697 else if (sym_is(symname, "__mod_pcmcia_device_table"))
641 do_table(symval, sym->st_size, 698 do_table(symval, sym->st_size,
642 sizeof(struct pcmcia_device_id), "pcmcia", 699 sizeof(struct pcmcia_device_id), "pcmcia",
@@ -673,6 +730,10 @@ void handle_moddevtable(struct module *mod, struct elf_info *info,
673 do_table(symval, sym->st_size, 730 do_table(symval, sym->st_size,
674 sizeof(struct virtio_device_id), "virtio", 731 sizeof(struct virtio_device_id), "virtio",
675 do_virtio_entry, mod); 732 do_virtio_entry, mod);
733 else if (sym_is(symname, "__mod_i2c_device_table"))
734 do_table(symval, sym->st_size,
735 sizeof(struct i2c_device_id), "i2c",
736 do_i2c_entry, mod);
676 free(zeros); 737 free(zeros);
677} 738}
678 739