Re: [patch] 2.4.11-pre4 remove spurious kernel recompiles

Andrea Arcangeli (andrea@suse.de)
Mon, 8 Oct 2001 04:12:15 +0200


On Mon, Oct 08, 2001 at 11:34:04AM +1000, Keith Owens wrote:
> On Mon, 8 Oct 2001 03:20:23 +0200,
> Andrea Arcangeli <andrea@suse.de> wrote:
> >On Mon, Oct 08, 2001 at 10:42:56AM +1000, Keith Owens wrote:
> >> IOW a check for Makefile timestamp is both overkill (it recompiles too
> >> much) and incomplete (it does not detect command line overrides). BTW,
> >> kbuild 2.5 gets this right.
> >
> >That sounds fine. Of course the only regression could be the build time.
> >Do you have a benchmark on the build time with kbuild 2.5 applied to
> >2.4.10 compared to the build time of 2.4.10?
>
> kbuild 2.5 build times vary from 10% faster to 100% slower, depending
> on the number of objects being compiled. There are some O(n^2)

I meant for a stright compile, which is going to be its worst case and
my common case.

The main thing I like is to be able to compile out of the tree and
avoiding touching the header files during compilation (that's really
annoying).

> algorithms in kbuild 2.5, I know where they are and how to fix them, it
> just takes time that I don't have right now. At the moment I am
> concentrating on correctness for kbuild 2.5. MEC mantra:
>
> Correctness comes first.
> Then maintainability.
> Then speed.

I personally don't care about correctness in the sense of getting "make"
doing everything for you regardless of what you changed, I'm fine with
some "make distclean" forced checkpoint after PATCHLEVEL changed etc...,
you said infact full compile is needed sometime, not to tell about
kernel configuration.

One good example is the mkdep hack, it's far from correct: the header
dependences is nearly random. We cannot trust it unless we remeber
every user included us (one more reason I'm used to full recompiles),
but it's much faster than the correct full dependences generated by gcc
so I'm fine with it. When I compile other projects like kde2 I'm amazed
how slow the compilation is, ok it's not stright C but I bet the
correctness of its dependences hits a lot too on the compilation time
(but it's rebuilt in background so I don't care if it's slow while for
the kernel I'm sometime more synchronous waiting for the compilation to
finish :).

> BTW, how can you apply a -ac patch that sets SUBLEVEL backwards? -ac

First backout Linus's pre patch, then apply AC's -ac. The end result is
a backwards SUBLEVEL.

Andrea
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/