aboutsummaryrefslogtreecommitdiffstats
path: root/scripts/basic/fixdep.c
diff options
context:
space:
mode:
authorMichal Marek <mmarek@suse.cz>2011-03-11 16:34:47 -0500
committerLinus Torvalds <torvalds@linux-foundation.org>2011-03-13 18:59:58 -0400
commit7840fea200cd1ad93ed19853a83752a21f691326 (patch)
treee13f604355993207d34cc5abe335ec944ff871d7 /scripts/basic/fixdep.c
parente8444a3e3b56b268c6ca31a2f77040fd944834fb (diff)
kbuild: Fix computing srcversion for modules
Recent change to fixdep: commit b7bd182176960fdd139486cadb9962b39f8a2b50 Author: Michal Marek <mmarek@suse.cz> Date: Thu Feb 17 15:13:54 2011 +0100 fixdep: Do not record dependency on the source file itself changed the format of the *.cmd files without realizing that it is also used by modpost. Put the path to the source file to the file back, in a special variable, so that modpost sees all source files when calculating srcversion for modules. Reported-and-tested-by: Henrik Rydberg <rydberg@euromail.se> Signed-off-by: Michal Marek <mmarek@suse.cz> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'scripts/basic/fixdep.c')
-rw-r--r--scripts/basic/fixdep.c19
1 files changed, 13 insertions, 6 deletions
diff --git a/scripts/basic/fixdep.c b/scripts/basic/fixdep.c
index 6c94c6ce2925..291228e25984 100644
--- a/scripts/basic/fixdep.c
+++ b/scripts/basic/fixdep.c
@@ -309,6 +309,11 @@ static void do_config_file(const char *filename)
309 close(fd); 309 close(fd);
310} 310}
311 311
312/*
313 * Important: The below generated source_foo.o and deps_foo.o variable
314 * assignments are parsed not only by make, but also by the rather simple
315 * parser in scripts/mod/sumversion.c.
316 */
312static void parse_dep_file(void *map, size_t len) 317static void parse_dep_file(void *map, size_t len)
313{ 318{
314 char *m = map; 319 char *m = map;
@@ -323,7 +328,6 @@ static void parse_dep_file(void *map, size_t len)
323 exit(1); 328 exit(1);
324 } 329 }
325 memcpy(s, m, p-m); s[p-m] = 0; 330 memcpy(s, m, p-m); s[p-m] = 0;
326 printf("deps_%s := \\\n", target);
327 m = p+1; 331 m = p+1;
328 332
329 clear_config(); 333 clear_config();
@@ -343,12 +347,15 @@ static void parse_dep_file(void *map, size_t len)
343 strrcmp(s, "arch/um/include/uml-config.h") && 347 strrcmp(s, "arch/um/include/uml-config.h") &&
344 strrcmp(s, ".ver")) { 348 strrcmp(s, ".ver")) {
345 /* 349 /*
346 * Do not output the first dependency (the 350 * Do not list the source file as dependency, so that
347 * source file), so that kbuild is not confused 351 * kbuild is not confused if a .c file is rewritten
348 * if a .c file is rewritten into .S or vice 352 * into .S or vice versa. Storing it in source_* is
349 * versa. 353 * needed for modpost to compute srcversions.
350 */ 354 */
351 if (!first) 355 if (first) {
356 printf("source_%s := %s\n\n", target, s);
357 printf("deps_%s := \\\n", target);
358 } else
352 printf(" %s \\\n", s); 359 printf(" %s \\\n", s);
353 do_config_file(s); 360 do_config_file(s);
354 } 361 }