aboutsummaryrefslogtreecommitdiffstats
path: root/scripts/mod
diff options
context:
space:
mode:
Diffstat (limited to 'scripts/mod')
-rw-r--r--scripts/mod/modpost.c32
1 files changed, 30 insertions, 2 deletions
diff --git a/scripts/mod/modpost.c b/scripts/mod/modpost.c
index f7a0392ad1ca..1f90961ada77 100644
--- a/scripts/mod/modpost.c
+++ b/scripts/mod/modpost.c
@@ -15,6 +15,7 @@
15#include <stdio.h> 15#include <stdio.h>
16#include <ctype.h> 16#include <ctype.h>
17#include <string.h> 17#include <string.h>
18#include <limits.h>
18#include <stdbool.h> 19#include <stdbool.h>
19#include "modpost.h" 20#include "modpost.h"
20#include "../../include/generated/autoconf.h" 21#include "../../include/generated/autoconf.h"
@@ -1763,6 +1764,27 @@ static void read_symbols(char *modname)
1763 mod->unres = alloc_symbol("module_layout", 0, mod->unres); 1764 mod->unres = alloc_symbol("module_layout", 0, mod->unres);
1764} 1765}
1765 1766
1767static void read_symbols_from_files(const char *filename)
1768{
1769 FILE *in = stdin;
1770 char fname[PATH_MAX];
1771
1772 if (strcmp(filename, "-") != 0) {
1773 in = fopen(filename, "r");
1774 if (!in)
1775 fatal("Can't open filenames file %s: %m", filename);
1776 }
1777
1778 while (fgets(fname, PATH_MAX, in) != NULL) {
1779 if (strends(fname, "\n"))
1780 fname[strlen(fname)-1] = '\0';
1781 read_symbols(fname);
1782 }
1783
1784 if (in != stdin)
1785 fclose(in);
1786}
1787
1766#define SZ 500 1788#define SZ 500
1767 1789
1768/* We first write the generated file into memory using the 1790/* We first write the generated file into memory using the
@@ -2124,13 +2146,13 @@ int main(int argc, char **argv)
2124 struct module *mod; 2146 struct module *mod;
2125 struct buffer buf = { }; 2147 struct buffer buf = { };
2126 char *kernel_read = NULL, *module_read = NULL; 2148 char *kernel_read = NULL, *module_read = NULL;
2127 char *dump_write = NULL; 2149 char *dump_write = NULL, *files_source = NULL;
2128 int opt; 2150 int opt;
2129 int err; 2151 int err;
2130 struct ext_sym_list *extsym_iter; 2152 struct ext_sym_list *extsym_iter;
2131 struct ext_sym_list *extsym_start = NULL; 2153 struct ext_sym_list *extsym_start = NULL;
2132 2154
2133 while ((opt = getopt(argc, argv, "i:I:e:msSo:awM:K:")) != -1) { 2155 while ((opt = getopt(argc, argv, "i:I:e:msST:o:awM:K:")) != -1) {
2134 switch (opt) { 2156 switch (opt) {
2135 case 'i': 2157 case 'i':
2136 kernel_read = optarg; 2158 kernel_read = optarg;
@@ -2162,6 +2184,9 @@ int main(int argc, char **argv)
2162 case 'S': 2184 case 'S':
2163 sec_mismatch_verbose = 0; 2185 sec_mismatch_verbose = 0;
2164 break; 2186 break;
2187 case 'T':
2188 files_source = optarg;
2189 break;
2165 case 'w': 2190 case 'w':
2166 warn_unresolved = 1; 2191 warn_unresolved = 1;
2167 break; 2192 break;
@@ -2184,6 +2209,9 @@ int main(int argc, char **argv)
2184 while (optind < argc) 2209 while (optind < argc)
2185 read_symbols(argv[optind++]); 2210 read_symbols(argv[optind++]);
2186 2211
2212 if (files_source)
2213 read_symbols_from_files(files_source);
2214
2187 for (mod = modules; mod; mod = mod->next) { 2215 for (mod = modules; mod; mod = mod->next) {
2188 if (mod->skip) 2216 if (mod->skip)
2189 continue; 2217 continue;