kbuild: unconditionally clobber include/linux/version.h on distclean
authorPaul Gortmaker <paul.gortmaker@windriver.com>
Thu, 13 Feb 2014 21:28:58 +0000 (16:28 -0500)
committerMichal Marek <mmarek@suse.cz>
Sat, 29 Mar 2014 19:58:18 +0000 (20:58 +0100)
commit9c8cdb71644a22c2ffa0a7daa1b54cb6ed718c47
tree1e077959ec977fda5b1150e777128d4f4e7463dd
parent100da4c0150c97ce34d4d3b38bf2f5449b05ae4f
kbuild: unconditionally clobber include/linux/version.h on distclean

As of v3.7, the UAPI changes relocated headers around such that the
kernel version header lived in a new place.

If a person is bisecting and if you go back to pre-UAPI days,
you will create an include/linux/version.h  -- then if you checkout a
post-UAPI kernel, and even run "make distclean" it still won't delete
that old version file.  So you get a situation like this:

$ grep -R LINUX_VERSION_CODE include/
include/generated/uapi/linux/version.h:#define LINUX_VERSION_CODE 200192
include/linux/version.h:#define LINUX_VERSION_CODE 132646

The value in that second line is representative of a v2.6.38 version.
And it will be sourced/used, hence leading to strange behaviours, such
as drivers/staging content (which typically hasn't been purged of version
ifdefs) failing to build.

Since it is a subtle mode of failure, lets always clobber the old
file when doing a distclean.

Signed-off-by: Paul Gortmaker <paul.gortmaker@windriver.com>
Acked-by: David Howells <dhowells@redhat.com>
Signed-off-by: Michal Marek <mmarek@suse.cz>
Makefile