This is already true of the aic7xxx/Makefile for 2.4 since it will
have a second target shortly. I even spent yesturday changing the
file from AIC7XXX-OBJ to obj-aic7xxx to better follow your example.
In the next release, scsi/Makefile will also include aic7xxx.o instead
of aic7xxx_drv.o as you requested.
I have not looked at 2.5.
>* stop shipping files and overwriting them at run time
>* make the decision about firmware generation automatic instead of
> manual
Not this again.
SHIPPING GENERATED FILES
In general, it is bad practice to even attempt to ship generated files
in the Linux kernel build with the source of the utilities to build those
files as in Linux you can't know what miss-match of tools the user is going
to have. If you're lucky, they have a compiler with bugs that won't affect
you, but since there is no "standard toolset" that userland distributions
include, you cannot rely on even the tools that are necessary to rebuild the
compiler: lex and yacc. Even if the tools to build the tools to generate
your files exist in all cases (toungue twister), triggering the tool build
from within the kernel build can be "interesting" as you try and dissassociate
the tool make environment from the kernel build environment which may make
assumptions that don't apply to your tool.
The whole reliance on using patches as a general purpose upgrade tool
in Linux is left for another discussion. My only hope is that with the
move to using bitkeeper, this reliance will fade.
So, we are left with three options:
1) Don't bother shipping the code to regenerate the file.
2) Make it manually selectable for the .00000001% of users that
might want or need to modify the generated files.
3) Make the makefiles rely on sed, md5, and cmp in addition to
gmake and sh, an additional generated file and a script to automate
a process that really doesn't benefit from being automated.
Option #3 is simply complicated and overengineered.
The mechanism we have in place today works. Other than one mixup in
May or June of 2001, during the early adoption of this driver, it has
always worked.
The old driver included the firmware source but no tools to rebuild it.
I will happily do the same if this is more aesthetically pleasing.
Considering that this is an open source project, it just seems silly to
me to not ship the tools too as there is already a simple mechanism to
allow their use in place already.
>* remove the BSD'isms from the Linux aic7xxx Makefiles
Are you talking about aic7xxx/aicasm/Makefile? That makefile
does not use kbuild mecanisms becaues it is building a userland
application. The aic7xxx/Makefile (at least for 2.4 - again haven't
even looked at 2.5) seems to follow your own suggestions assuming
there will be two targets.
>then I will happily write clean aic7xxx makefiles and support them.
>But if you insist on doing it your own way that does not match the
>Linux kernel build, then I am afraid that you are on your own.
Then why bother sending a patch to Marcello?
-- Justin - 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/