Re: [PATCH] Fix 'make rpm' when CONFIG_LOCALVERSION_AUTO=y andusing SCM tree

From: Josh Hunt
Date: Mon Feb 16 2009 - 19:11:04 EST


On Sun, Feb 15, 2009 at 10:03:01AM +0100, Sam Ravnborg wrote:
>
> I had to hand apply your patch and ended up with the following.

Sorry, not sure what happened there.

>
> Changes:
> - renamed from autoversion to scmversion
> - simpler logic in top-level Makefile
> - removed "set -e;" in scripts/package/Makefile - they are not needed
>
> Please test.

The changes look good. All tested and works fine.

I'm still a little new to this - let me know if I need to resubmit
with your changes or if I need to provide anything else.

Thanks
Josh

>
> diff --git a/Makefile b/Makefile
> index 22d7584..3824446 100644
> --- a/Makefile
> +++ b/Makefile
> @@ -903,12 +903,18 @@ localver = $(subst $(space),, $(string) \
> # and if the SCM is know a tag from the SCM is appended.
> # The appended tag is determined by the SCM used.
> #
> -# Currently, only git is supported.
> -# Other SCMs can edit scripts/setlocalversion and add the appropriate
> -# checks as needed.
> +# .scmversion is used when generating rpm packages so we do not loose
> +# the version information from the SCM when we do the build of the kernel
> +# from the copied source
> ifdef CONFIG_LOCALVERSION_AUTO
> - _localver-auto = $(shell $(CONFIG_SHELL) \
> - $(srctree)/scripts/setlocalversion $(srctree))
> +
> +ifeq ($(wildcard .scmversion),)
> + _localver-auto = $(shell $(CONFIG_SHELL) \
> + $(srctree)/scripts/setlocalversion $(srctree))
> +else
> + _localver-auto = $(shell cat .scmversion 2> /dev/null)
> +endif
> +
> localver-auto = $(LOCALVERSION)$(_localver-auto)
> endif
>
> diff --git a/scripts/package/Makefile b/scripts/package/Makefile
> index 8c6b7b0..fa4a0a1 100644
> --- a/scripts/package/Makefile
> +++ b/scripts/package/Makefile
> @@ -35,9 +35,10 @@ $(objtree)/kernel.spec: $(MKSPEC) $(srctree)/Makefile
> rpm-pkg rpm: $(objtree)/kernel.spec FORCE
> $(MAKE) clean
> $(PREV) ln -sf $(srctree) $(KERNELPATH)
> + $(CONFIG_SHELL) $(srctree)/scripts/setlocalversion > $(objtree)/.scmversion
> $(PREV) tar -cz $(RCS_TAR_IGNORE) -f $(KERNELPATH).tar.gz $(KERNELPATH)/.
> $(PREV) rm $(KERNELPATH)
> -
> + rm -f $(objtree)/.scmversion
> set -e; \
> $(CONFIG_SHELL) $(srctree)/scripts/mkversion > $(objtree)/.tmp_version
> set -e; \
> --
> To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
> the body of a message to majordomo@xxxxxxxxxxxxxxx
> More majordomo info at http://vger.kernel.org/majordomo-info.html
> Please read the FAQ at http://www.tux.org/lkml/
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/