From fb2647aaf55b453b37badfd40c14c59486a74584 Mon Sep 17 00:00:00 2001 From: Richard Biener Date: Tue, 3 May 2016 08:14:27 +0000 Subject: [PATCH] Make-lang.in (cc1-checksum.c): For stage-final re-use the checksum from the previous stage. 2016-05-03 Richard Biener c/ * Make-lang.in (cc1-checksum.c): For stage-final re-use the checksum from the previous stage. cp/ * Make-lang.in (cc1plus-checksum.c): For stage-final re-use the checksum from the previous stage. From-SVN: r235804 --- gcc/c/ChangeLog | 5 +++++ gcc/c/Make-lang.in | 11 +++++++++-- gcc/cp/ChangeLog | 5 +++++ gcc/cp/Make-lang.in | 11 +++++++++-- 4 files changed, 28 insertions(+), 4 deletions(-) diff --git a/gcc/c/ChangeLog b/gcc/c/ChangeLog index a90972e7e09..ae6275968c6 100644 --- a/gcc/c/ChangeLog +++ b/gcc/c/ChangeLog @@ -1,3 +1,8 @@ +2016-05-03 Richard Biener + + * Make-lang.in (cc1-checksum.c): For stage-final re-use + the checksum from the previous stage. + 2016-05-02 Cesar Philippidis * c-parser.c (c_parser_oacc_all_clauses): Update call to diff --git a/gcc/c/Make-lang.in b/gcc/c/Make-lang.in index 8525707f996..34c8b0ed856 100644 --- a/gcc/c/Make-lang.in +++ b/gcc/c/Make-lang.in @@ -61,11 +61,18 @@ c_OBJS = $(C_OBJS) cc1-checksum.o c/gccspec.o c-warn = $(STRICT_WARN) # compute checksum over all object files and the options +# re-use the checksum from the prev-final stage so it passes +# the bootstrap comparison and allows comparing of the cc1 binary cc1-checksum.c : build/genchecksum$(build_exeext) checksum-options \ $(C_OBJS) $(BACKEND) $(LIBDEPS) - build/genchecksum$(build_exeext) $(C_OBJS) $(BACKEND) $(LIBDEPS) \ + if [ -f ../stage_final ] \ + && cmp -s ../stage_current ../stage_final; then \ + cp ../prev-gcc/cc1-checksum.c cc1-checksum.c; \ + else \ + build/genchecksum$(build_exeext) $(C_OBJS) $(BACKEND) $(LIBDEPS) \ checksum-options > cc1-checksum.c.tmp && \ - $(srcdir)/../move-if-change cc1-checksum.c.tmp cc1-checksum.c + $(srcdir)/../move-if-change cc1-checksum.c.tmp cc1-checksum.c; \ + fi cc1$(exeext): $(C_OBJS) cc1-checksum.o $(BACKEND) $(LIBDEPS) +$(LLINKER) $(ALL_LINKERFLAGS) $(LDFLAGS) -o $@ $(C_OBJS) \ diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 990ba0fb719..497bc0ec967 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,8 @@ +2016-05-03 Richard Biener + + * Make-lang.in (cc1plus-checksum.c): For stage-final re-use + the checksum from the previous stage. + 2016-05-02 David Malcolm PR c++/62314 diff --git a/gcc/cp/Make-lang.in b/gcc/cp/Make-lang.in index 8770f6ff1be..625a77c5386 100644 --- a/gcc/cp/Make-lang.in +++ b/gcc/cp/Make-lang.in @@ -90,11 +90,18 @@ c++_OBJS = $(CXX_OBJS) cc1plus-checksum.o cp/g++spec.o cp-warn = $(STRICT_WARN) # compute checksum over all object files and the options +# re-use the checksum from the prev-final stage so it passes +# the bootstrap comparison and allows comparing of the cc1 binary cc1plus-checksum.c : build/genchecksum$(build_exeext) checksum-options \ $(CXX_OBJS) $(BACKEND) $(LIBDEPS) - build/genchecksum$(build_exeext) $(CXX_OBJS) $(BACKEND) $(LIBDEPS) \ + if [ -f ../stage_final ] \ + && cmp -s ../stage_current ../stage_final; then \ + cp ../prev-gcc/cc1plus-checksum.c cc1plus-checksum.c; \ + else \ + build/genchecksum$(build_exeext) $(CXX_OBJS) $(BACKEND) $(LIBDEPS) \ checksum-options > cc1plus-checksum.c.tmp && \ - $(srcdir)/../move-if-change cc1plus-checksum.c.tmp cc1plus-checksum.c + $(srcdir)/../move-if-change cc1plus-checksum.c.tmp cc1plus-checksum.c; \ + fi cc1plus$(exeext): $(CXX_OBJS) cc1plus-checksum.o $(BACKEND) $(LIBDEPS) +$(LLINKER) $(ALL_LINKERFLAGS) $(LDFLAGS) -o $@ \