Applied, thanks
On Thu, Apr 12, 2018 at 10:36 AM, Michael Olbrich <m.olbr...@pengutronix.de> wrote: > The files generated by the include/config/MARKER target are in the > dependency list for applets/applet_tables. > If applets/applet_tables is created first during applets_dir then it will > be created again later as part of $(busybox-dirs). > As a result include/applet_tables.h is created again. This time while other > build commands may need it. > > Let applets_dir depend on include/config/MARKER to avoid this particular > race condition and create the header files atomically to ensure that the > compiler never sees incomplete files. > > Signed-off-by: Michael Olbrich <m.olbr...@pengutronix.de> > --- > > Next try, this time with the correct dependency. > > Michael > > Makefile | 2 +- > applets/applet_tables.c | 16 ++++++++++++++-- > 2 files changed, 15 insertions(+), 3 deletions(-) > > diff --git a/Makefile b/Makefile > index 03a57adf3204..9d7a0a36c149 100644 > --- a/Makefile > +++ b/Makefile > @@ -368,7 +368,7 @@ gen_build_files: $(wildcard $(srctree)/*/*.c) $(wildcard > $(srctree)/*/*/*.c) > # we depend on scripts_basic, since scripts/basic/fixdep > # must be built before any other host prog > PHONY += applets_dir > -applets_dir: scripts_basic gen_build_files > +applets_dir: scripts_basic gen_build_files include/config/MARKER > $(Q)$(MAKE) $(build)=applets > > applets/%: applets_dir ; > diff --git a/applets/applet_tables.c b/applets/applet_tables.c > index ef911a43b36d..e3d10c83f1b9 100644 > --- a/applets/applet_tables.c > +++ b/applets/applet_tables.c > @@ -10,6 +10,7 @@ > #include <sys/types.h> > #include <sys/stat.h> > #include <fcntl.h> > +#include <limits.h> > #include <stdlib.h> > #include <string.h> > #include <stdio.h> > @@ -61,6 +62,7 @@ static int str_isalnum_(const char *s) > int main(int argc, char **argv) > { > int i, j; > + char tmp1[PATH_MAX], tmp2[PATH_MAX]; > > // In find_applet_by_name(), before linear search, narrow it down > // by looking at N "equidistant" names. With ~350 applets: > @@ -84,7 +86,8 @@ int main(int argc, char **argv) > > if (!argv[1]) > return 1; > - i = open(argv[1], O_WRONLY | O_TRUNC | O_CREAT, 0666); > + snprintf(tmp1, PATH_MAX, "%s.%u.new", argv[1], (int) getpid()); > + i = open(tmp1, O_WRONLY | O_TRUNC | O_CREAT, 0666); > if (i < 0) > return 1; > dup2(i, 1); > @@ -209,12 +212,21 @@ int main(int argc, char **argv) > // fclose(fp); > // } > // if (strcmp(line_old, line_new) != 0) { > - fp = fopen(argv[2], "w"); > + snprintf(tmp2, PATH_MAX, "%s.%u.new", argv[2], (int) > getpid()); > + fp = fopen(tmp2, "w"); > if (!fp) > return 1; > fputs(line_new, fp); > + if (fclose(fp)) > + return 1; > // } > } > > + if (fclose(stdout)) > + return 1; > + if (rename(tmp1, argv[1])) > + return 1; > + if (rename(tmp2, argv[2])) > + return 1; > return 0; > } > -- > 2.17.0 > > _______________________________________________ > busybox mailing list > busybox@busybox.net > http://lists.busybox.net/mailman/listinfo/busybox _______________________________________________ busybox mailing list busybox@busybox.net http://lists.busybox.net/mailman/listinfo/busybox