diff options
author | Segher Boessenkool <segher@kernel.crashing.org> | 2007-05-19 12:49:07 -0400 |
---|---|---|
committer | Sam Ravnborg <sam@ravnborg.org> | 2007-07-16 15:15:47 -0400 |
commit | 0ab2a272e6b55e5d58168d6983da99e2dc09b8b2 (patch) | |
tree | 16db20cec448da4816e4c3f24f6ecf7b445e02a4 /scripts | |
parent | f241182b51c0f26b29af40c3777f84e6033d0401 (diff) |
kbuild: New 'cc-fullversion' macro
Prints a six-digit string including the GCC patchlevel. Also fix
the 'usage' comment for cc-version.
Signed-off-by: Segher Boessenkool <segher@kernel.crashing.org>
Signed-off-by: Sam Ravnborg <sam@ravnborg.org>
Diffstat (limited to 'scripts')
-rw-r--r-- | scripts/Kbuild.include | 7 | ||||
-rw-r--r-- | scripts/gcc-version.sh | 15 |
2 files changed, 18 insertions, 4 deletions
diff --git a/scripts/Kbuild.include b/scripts/Kbuild.include index 06c1a377c4c5..677bc6c175cb 100644 --- a/scripts/Kbuild.include +++ b/scripts/Kbuild.include | |||
@@ -100,9 +100,14 @@ cc-option-align = $(subst -functions=0,,\ | |||
100 | $(call cc-option,-falign-functions=0,-malign-functions=0)) | 100 | $(call cc-option,-falign-functions=0,-malign-functions=0)) |
101 | 101 | ||
102 | # cc-version | 102 | # cc-version |
103 | # Usage gcc-ver := $(call cc-version,$(CC)) | 103 | # Usage gcc-ver := $(call cc-version) |
104 | cc-version = $(shell $(CONFIG_SHELL) $(srctree)/scripts/gcc-version.sh $(CC)) | 104 | cc-version = $(shell $(CONFIG_SHELL) $(srctree)/scripts/gcc-version.sh $(CC)) |
105 | 105 | ||
106 | # cc-fullversion | ||
107 | # Usage gcc-ver := $(call cc-fullversion) | ||
108 | cc-fullversion = $(shell $(CONFIG_SHELL) \ | ||
109 | $(srctree)/scripts/gcc-version.sh -p $(CC)) | ||
110 | |||
106 | # cc-ifversion | 111 | # cc-ifversion |
107 | # Usage: EXTRA_CFLAGS += $(call cc-ifversion, -lt, 0402, -O1) | 112 | # Usage: EXTRA_CFLAGS += $(call cc-ifversion, -lt, 0402, -O1) |
108 | cc-ifversion = $(shell [ $(call cc-version, $(CC)) $(1) $(2) ] && echo $(3)) | 113 | cc-ifversion = $(shell [ $(call cc-version, $(CC)) $(1) $(2) ] && echo $(3)) |
diff --git a/scripts/gcc-version.sh b/scripts/gcc-version.sh index bb4fbeab8320..8a1d1879c7ad 100644 --- a/scripts/gcc-version.sh +++ b/scripts/gcc-version.sh | |||
@@ -1,14 +1,23 @@ | |||
1 | #!/bin/sh | 1 | #!/bin/sh |
2 | # | 2 | # |
3 | # gcc-version gcc-command | 3 | # gcc-version [-p] gcc-command |
4 | # | 4 | # |
5 | # Prints the gcc version of `gcc-command' in a canonical 4-digit form | 5 | # Prints the gcc version of `gcc-command' in a canonical 4-digit form |
6 | # such as `0295' for gcc-2.95, `0303' for gcc-3.3, etc. | 6 | # such as `0295' for gcc-2.95, `0303' for gcc-3.3, etc. |
7 | # | 7 | # |
8 | # With the -p option, prints the patchlevel as well, for example `029503' for | ||
9 | # gcc-2.95.3, `030301' for gcc-3.3.1, etc. | ||
10 | # | ||
11 | |||
12 | if [ $1 = "-p" ] ; then with_patchlevel=1; shift; fi | ||
8 | 13 | ||
9 | compiler="$*" | 14 | compiler="$*" |
10 | 15 | ||
11 | MAJOR=$(echo __GNUC__ | $compiler -E -xc - | tail -n 1) | 16 | MAJOR=$(echo __GNUC__ | $compiler -E -xc - | tail -n 1) |
12 | MINOR=$(echo __GNUC_MINOR__ | $compiler -E -xc - | tail -n 1) | 17 | MINOR=$(echo __GNUC_MINOR__ | $compiler -E -xc - | tail -n 1) |
13 | printf "%02d%02d\\n" $MAJOR $MINOR | 18 | if [ "x$with_patchlevel" != "x" ] ; then |
14 | 19 | PATCHLEVEL=$(echo __GNUC_PATCHLEVEL__ | $compiler -E -xc - | tail -n 1) | |
20 | printf "%02d%02d%02d\\n" $MAJOR $MINOR $PATCHLEVEL | ||
21 | else | ||
22 | printf "%02d%02d\\n" $MAJOR $MINOR | ||
23 | fi | ||