diff options
| author | Benjamin Herrenschmidt <benh@kernel.crashing.org> | 2008-10-14 20:31:54 -0400 |
|---|---|---|
| committer | Benjamin Herrenschmidt <benh@kernel.crashing.org> | 2008-10-14 20:31:54 -0400 |
| commit | 6dc6472581f693b5fc95aebedf67b4960fb85cf0 (patch) | |
| tree | 06a5a9a08519950575505273eabced331ed51405 /scripts/mod | |
| parent | ee673eaa72d8d185012b1027a05e25aba18c267f (diff) | |
| parent | 8acd3a60bcca17c6d89c73cee3ad6057eb83ba1e (diff) | |
Merge commit 'origin'
Manual fixup of conflicts on:
arch/powerpc/include/asm/dcr-regs.h
drivers/net/ibm_newemac/core.h
Diffstat (limited to 'scripts/mod')
| -rw-r--r-- | scripts/mod/file2alias.c | 57 | ||||
| -rw-r--r-- | scripts/mod/modpost.c | 6 |
2 files changed, 61 insertions, 2 deletions
diff --git a/scripts/mod/file2alias.c b/scripts/mod/file2alias.c index 4c9890ec2528..473f94e56ead 100644 --- a/scripts/mod/file2alias.c +++ b/scripts/mod/file2alias.c | |||
| @@ -629,6 +629,59 @@ static int do_i2c_entry(const char *filename, struct i2c_device_id *id, | |||
| 629 | return 1; | 629 | return 1; |
| 630 | } | 630 | } |
| 631 | 631 | ||
| 632 | static const struct dmifield { | ||
| 633 | const char *prefix; | ||
| 634 | int field; | ||
| 635 | } dmi_fields[] = { | ||
| 636 | { "bvn", DMI_BIOS_VENDOR }, | ||
| 637 | { "bvr", DMI_BIOS_VERSION }, | ||
| 638 | { "bd", DMI_BIOS_DATE }, | ||
| 639 | { "svn", DMI_SYS_VENDOR }, | ||
| 640 | { "pn", DMI_PRODUCT_NAME }, | ||
| 641 | { "pvr", DMI_PRODUCT_VERSION }, | ||
| 642 | { "rvn", DMI_BOARD_VENDOR }, | ||
| 643 | { "rn", DMI_BOARD_NAME }, | ||
| 644 | { "rvr", DMI_BOARD_VERSION }, | ||
| 645 | { "cvn", DMI_CHASSIS_VENDOR }, | ||
| 646 | { "ct", DMI_CHASSIS_TYPE }, | ||
| 647 | { "cvr", DMI_CHASSIS_VERSION }, | ||
| 648 | { NULL, DMI_NONE } | ||
| 649 | }; | ||
| 650 | |||
| 651 | static void dmi_ascii_filter(char *d, const char *s) | ||
| 652 | { | ||
| 653 | /* Filter out characters we don't want to see in the modalias string */ | ||
| 654 | for (; *s; s++) | ||
| 655 | if (*s > ' ' && *s < 127 && *s != ':') | ||
| 656 | *(d++) = *s; | ||
| 657 | |||
| 658 | *d = 0; | ||
| 659 | } | ||
| 660 | |||
| 661 | |||
| 662 | static int do_dmi_entry(const char *filename, struct dmi_system_id *id, | ||
| 663 | char *alias) | ||
| 664 | { | ||
| 665 | int i, j; | ||
| 666 | |||
| 667 | sprintf(alias, "dmi*"); | ||
| 668 | |||
| 669 | for (i = 0; i < ARRAY_SIZE(dmi_fields); i++) { | ||
| 670 | for (j = 0; j < 4; j++) { | ||
| 671 | if (id->matches[j].slot && | ||
| 672 | id->matches[j].slot == dmi_fields[i].field) { | ||
| 673 | sprintf(alias + strlen(alias), ":%s*", | ||
| 674 | dmi_fields[i].prefix); | ||
| 675 | dmi_ascii_filter(alias + strlen(alias), | ||
| 676 | id->matches[j].substr); | ||
| 677 | strcat(alias, "*"); | ||
| 678 | } | ||
| 679 | } | ||
| 680 | } | ||
| 681 | |||
| 682 | strcat(alias, ":"); | ||
| 683 | return 1; | ||
| 684 | } | ||
| 632 | /* Ignore any prefix, eg. some architectures prepend _ */ | 685 | /* Ignore any prefix, eg. some architectures prepend _ */ |
| 633 | static inline int sym_is(const char *symbol, const char *name) | 686 | static inline int sym_is(const char *symbol, const char *name) |
| 634 | { | 687 | { |
| @@ -760,6 +813,10 @@ void handle_moddevtable(struct module *mod, struct elf_info *info, | |||
| 760 | do_table(symval, sym->st_size, | 813 | do_table(symval, sym->st_size, |
| 761 | sizeof(struct i2c_device_id), "i2c", | 814 | sizeof(struct i2c_device_id), "i2c", |
| 762 | do_i2c_entry, mod); | 815 | do_i2c_entry, mod); |
| 816 | else if (sym_is(symname, "__mod_dmi_device_table")) | ||
| 817 | do_table(symval, sym->st_size, | ||
| 818 | sizeof(struct dmi_system_id), "dmi", | ||
| 819 | do_dmi_entry, mod); | ||
| 763 | free(zeros); | 820 | free(zeros); |
| 764 | } | 821 | } |
| 765 | 822 | ||
diff --git a/scripts/mod/modpost.c b/scripts/mod/modpost.c index 418cd7dbbc93..8e0de6a5e18a 100644 --- a/scripts/mod/modpost.c +++ b/scripts/mod/modpost.c | |||
| @@ -1986,11 +1986,13 @@ static void read_markers(const char *fname) | |||
| 1986 | 1986 | ||
| 1987 | mod = find_module(modname); | 1987 | mod = find_module(modname); |
| 1988 | if (!mod) { | 1988 | if (!mod) { |
| 1989 | if (is_vmlinux(modname)) | ||
| 1990 | have_vmlinux = 1; | ||
| 1991 | mod = new_module(NOFAIL(strdup(modname))); | 1989 | mod = new_module(NOFAIL(strdup(modname))); |
| 1992 | mod->skip = 1; | 1990 | mod->skip = 1; |
| 1993 | } | 1991 | } |
| 1992 | if (is_vmlinux(modname)) { | ||
| 1993 | have_vmlinux = 1; | ||
| 1994 | mod->skip = 0; | ||
| 1995 | } | ||
| 1994 | 1996 | ||
| 1995 | if (!mod->skip) | 1997 | if (!mod->skip) |
| 1996 | add_marker(mod, marker, fmt); | 1998 | add_marker(mod, marker, fmt); |
