build: use git version and hash for boot banner
This uses the version and hash (git describe) and replaces the timestamp currently used in the boot banner. This works much better than using timestamps. It lets us point to the exact commit being used to run a certain application or test. Signed-off-by: Anas Nashif <anas.nashif@intel.com>
This commit is contained in:
parent
757c5d1857
commit
daf7716ddd
5 changed files with 227 additions and 13 deletions
|
@ -62,6 +62,12 @@ zephyr_compile_definitions(
|
||||||
)
|
)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
if(BUILD_VERSION)
|
||||||
|
zephyr_compile_definitions(
|
||||||
|
BUILD_VERSION=${BUILD_VERSION}
|
||||||
|
)
|
||||||
|
endif()
|
||||||
|
|
||||||
# We need to set an optimization level.
|
# We need to set an optimization level.
|
||||||
# Default to -Os
|
# Default to -Os
|
||||||
# unless CONFIG_NO_OPTIMIZATIONS is set, then it is -O0
|
# unless CONFIG_NO_OPTIMIZATIONS is set, then it is -O0
|
||||||
|
|
168
cmake/GetGitRevisionDescription.cmake
Normal file
168
cmake/GetGitRevisionDescription.cmake
Normal file
|
@ -0,0 +1,168 @@
|
||||||
|
# - Returns a version string from Git
|
||||||
|
#
|
||||||
|
# These functions force a re-configure on each git commit so that you can
|
||||||
|
# trust the values of the variables in your build system.
|
||||||
|
#
|
||||||
|
# get_git_head_revision(<refspecvar> <hashvar> [<additional arguments to git describe> ...])
|
||||||
|
#
|
||||||
|
# Returns the refspec and sha hash of the current head revision
|
||||||
|
#
|
||||||
|
# git_describe(<var> [<additional arguments to git describe> ...])
|
||||||
|
#
|
||||||
|
# Returns the results of git describe on the source tree, and adjusting
|
||||||
|
# the output so that it tests false if an error occurs.
|
||||||
|
#
|
||||||
|
# git_get_exact_tag(<var> [<additional arguments to git describe> ...])
|
||||||
|
#
|
||||||
|
# Returns the results of git describe --exact-match on the source tree,
|
||||||
|
# and adjusting the output so that it tests false if there was no exact
|
||||||
|
# matching tag.
|
||||||
|
#
|
||||||
|
# git_local_changes(<var>)
|
||||||
|
#
|
||||||
|
# Returns either "CLEAN" or "DIRTY" with respect to uncommitted changes.
|
||||||
|
# Uses the return code of "git diff-index --quiet HEAD --".
|
||||||
|
# Does not regard untracked files.
|
||||||
|
#
|
||||||
|
# Requires CMake 2.6 or newer (uses the 'function' command)
|
||||||
|
#
|
||||||
|
# Original Author:
|
||||||
|
# 2009-2010 Ryan Pavlik <rpavlik@iastate.edu> <abiryan@ryand.net>
|
||||||
|
# http://academic.cleardefinition.com
|
||||||
|
# Iowa State University HCI Graduate Program/VRAC
|
||||||
|
#
|
||||||
|
# Copyright Iowa State University 2009-2010.
|
||||||
|
# Distributed under the Boost Software License, Version 1.0.
|
||||||
|
# (See accompanying file LICENSE_1_0.txt or copy at
|
||||||
|
# http://www.boost.org/LICENSE_1_0.txt)
|
||||||
|
|
||||||
|
if(__get_git_revision_description)
|
||||||
|
return()
|
||||||
|
endif()
|
||||||
|
set(__get_git_revision_description YES)
|
||||||
|
|
||||||
|
# We must run the following at "include" time, not at function call time,
|
||||||
|
# to find the path to this module rather than the path to a calling list file
|
||||||
|
get_filename_component(_gitdescmoddir ${CMAKE_CURRENT_LIST_FILE} PATH)
|
||||||
|
|
||||||
|
function(get_git_head_revision _refspecvar _hashvar)
|
||||||
|
set(GIT_PARENT_DIR "${CMAKE_CURRENT_SOURCE_DIR}")
|
||||||
|
set(GIT_DIR "${GIT_PARENT_DIR}/.git")
|
||||||
|
while(NOT EXISTS "${GIT_DIR}") # .git dir not found, search parent directories
|
||||||
|
set(GIT_PREVIOUS_PARENT "${GIT_PARENT_DIR}")
|
||||||
|
get_filename_component(GIT_PARENT_DIR ${GIT_PARENT_DIR} PATH)
|
||||||
|
if(GIT_PARENT_DIR STREQUAL GIT_PREVIOUS_PARENT)
|
||||||
|
# We have reached the root directory, we are not in git
|
||||||
|
set(${_refspecvar} "GITDIR-NOTFOUND" PARENT_SCOPE)
|
||||||
|
set(${_hashvar} "GITDIR-NOTFOUND" PARENT_SCOPE)
|
||||||
|
return()
|
||||||
|
endif()
|
||||||
|
set(GIT_DIR "${GIT_PARENT_DIR}/.git")
|
||||||
|
endwhile()
|
||||||
|
# check if this is a submodule
|
||||||
|
if(NOT IS_DIRECTORY ${GIT_DIR})
|
||||||
|
file(READ ${GIT_DIR} submodule)
|
||||||
|
string(REGEX REPLACE "gitdir: (.*)\n$" "\\1" GIT_DIR_RELATIVE ${submodule})
|
||||||
|
get_filename_component(SUBMODULE_DIR ${GIT_DIR} PATH)
|
||||||
|
get_filename_component(GIT_DIR ${SUBMODULE_DIR}/${GIT_DIR_RELATIVE} ABSOLUTE)
|
||||||
|
endif()
|
||||||
|
set(GIT_DATA "${CMAKE_CURRENT_BINARY_DIR}/CMakeFiles/git-data")
|
||||||
|
if(NOT EXISTS "${GIT_DATA}")
|
||||||
|
file(MAKE_DIRECTORY "${GIT_DATA}")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(NOT EXISTS "${GIT_DIR}/HEAD")
|
||||||
|
return()
|
||||||
|
endif()
|
||||||
|
set(HEAD_FILE "${GIT_DATA}/HEAD")
|
||||||
|
configure_file("${GIT_DIR}/HEAD" "${HEAD_FILE}" COPYONLY)
|
||||||
|
|
||||||
|
configure_file("${_gitdescmoddir}/GetGitRevisionDescription.cmake.in"
|
||||||
|
"${GIT_DATA}/grabRef.cmake"
|
||||||
|
@ONLY)
|
||||||
|
include("${GIT_DATA}/grabRef.cmake")
|
||||||
|
|
||||||
|
set(${_refspecvar} "${HEAD_REF}" PARENT_SCOPE)
|
||||||
|
set(${_hashvar} "${HEAD_HASH}" PARENT_SCOPE)
|
||||||
|
endfunction()
|
||||||
|
|
||||||
|
function(git_describe _var)
|
||||||
|
if(NOT GIT_FOUND)
|
||||||
|
find_package(Git QUIET)
|
||||||
|
endif()
|
||||||
|
get_git_head_revision(refspec hash)
|
||||||
|
if(NOT GIT_FOUND)
|
||||||
|
set(${_var} "GIT-NOTFOUND" PARENT_SCOPE)
|
||||||
|
return()
|
||||||
|
endif()
|
||||||
|
if(NOT hash)
|
||||||
|
set(${_var} "HEAD-HASH-NOTFOUND" PARENT_SCOPE)
|
||||||
|
return()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# TODO sanitize
|
||||||
|
#if((${ARGN}" MATCHES "&&") OR
|
||||||
|
# (ARGN MATCHES "||") OR
|
||||||
|
# (ARGN MATCHES "\\;"))
|
||||||
|
# message("Please report the following error to the project!")
|
||||||
|
# message(FATAL_ERROR "Looks like someone's doing something nefarious with git_describe! Passed arguments ${ARGN}")
|
||||||
|
#endif()
|
||||||
|
|
||||||
|
#message(STATUS "Arguments to execute_process: ${ARGN}")
|
||||||
|
|
||||||
|
execute_process(COMMAND
|
||||||
|
"${GIT_EXECUTABLE}"
|
||||||
|
describe
|
||||||
|
${hash}
|
||||||
|
${ARGN}
|
||||||
|
WORKING_DIRECTORY
|
||||||
|
"${CMAKE_CURRENT_SOURCE_DIR}"
|
||||||
|
RESULT_VARIABLE
|
||||||
|
res
|
||||||
|
OUTPUT_VARIABLE
|
||||||
|
out
|
||||||
|
ERROR_QUIET
|
||||||
|
OUTPUT_STRIP_TRAILING_WHITESPACE)
|
||||||
|
if(NOT res EQUAL 0)
|
||||||
|
set(out "${out}-${res}-NOTFOUND")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
set(${_var} "${out}" PARENT_SCOPE)
|
||||||
|
endfunction()
|
||||||
|
|
||||||
|
function(git_get_exact_tag _var)
|
||||||
|
git_describe(out --exact-match ${ARGN})
|
||||||
|
set(${_var} "${out}" PARENT_SCOPE)
|
||||||
|
endfunction()
|
||||||
|
|
||||||
|
function(git_local_changes _var)
|
||||||
|
if(NOT GIT_FOUND)
|
||||||
|
find_package(Git QUIET)
|
||||||
|
endif()
|
||||||
|
get_git_head_revision(refspec hash)
|
||||||
|
if(NOT GIT_FOUND)
|
||||||
|
set(${_var} "GIT-NOTFOUND" PARENT_SCOPE)
|
||||||
|
return()
|
||||||
|
endif()
|
||||||
|
if(NOT hash)
|
||||||
|
set(${_var} "HEAD-HASH-NOTFOUND" PARENT_SCOPE)
|
||||||
|
return()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
execute_process(COMMAND
|
||||||
|
"${GIT_EXECUTABLE}"
|
||||||
|
diff-index --quiet HEAD --
|
||||||
|
WORKING_DIRECTORY
|
||||||
|
"${CMAKE_CURRENT_SOURCE_DIR}"
|
||||||
|
RESULT_VARIABLE
|
||||||
|
res
|
||||||
|
OUTPUT_VARIABLE
|
||||||
|
out
|
||||||
|
ERROR_QUIET
|
||||||
|
OUTPUT_STRIP_TRAILING_WHITESPACE)
|
||||||
|
if(res EQUAL 0)
|
||||||
|
set(${_var} "CLEAN" PARENT_SCOPE)
|
||||||
|
else()
|
||||||
|
set(${_var} "DIRTY" PARENT_SCOPE)
|
||||||
|
endif()
|
||||||
|
endfunction()
|
41
cmake/GetGitRevisionDescription.cmake.in
Normal file
41
cmake/GetGitRevisionDescription.cmake.in
Normal file
|
@ -0,0 +1,41 @@
|
||||||
|
#
|
||||||
|
# Internal file for GetGitRevisionDescription.cmake
|
||||||
|
#
|
||||||
|
# Requires CMake 2.6 or newer (uses the 'function' command)
|
||||||
|
#
|
||||||
|
# Original Author:
|
||||||
|
# 2009-2010 Ryan Pavlik <rpavlik@iastate.edu> <abiryan@ryand.net>
|
||||||
|
# http://academic.cleardefinition.com
|
||||||
|
# Iowa State University HCI Graduate Program/VRAC
|
||||||
|
#
|
||||||
|
# Copyright Iowa State University 2009-2010.
|
||||||
|
# Distributed under the Boost Software License, Version 1.0.
|
||||||
|
# (See accompanying file LICENSE_1_0.txt or copy at
|
||||||
|
# http://www.boost.org/LICENSE_1_0.txt)
|
||||||
|
|
||||||
|
set(HEAD_HASH)
|
||||||
|
|
||||||
|
file(READ "@HEAD_FILE@" HEAD_CONTENTS LIMIT 1024)
|
||||||
|
|
||||||
|
string(STRIP "${HEAD_CONTENTS}" HEAD_CONTENTS)
|
||||||
|
if(HEAD_CONTENTS MATCHES "ref")
|
||||||
|
# named branch
|
||||||
|
string(REPLACE "ref: " "" HEAD_REF "${HEAD_CONTENTS}")
|
||||||
|
if(EXISTS "@GIT_DIR@/${HEAD_REF}")
|
||||||
|
configure_file("@GIT_DIR@/${HEAD_REF}" "@GIT_DATA@/head-ref" COPYONLY)
|
||||||
|
else()
|
||||||
|
configure_file("@GIT_DIR@/packed-refs" "@GIT_DATA@/packed-refs" COPYONLY)
|
||||||
|
file(READ "@GIT_DATA@/packed-refs" PACKED_REFS)
|
||||||
|
if(${PACKED_REFS} MATCHES "([0-9a-z]*) ${HEAD_REF}")
|
||||||
|
set(HEAD_HASH "${CMAKE_MATCH_1}")
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
else()
|
||||||
|
# detached HEAD
|
||||||
|
configure_file("@GIT_DIR@/HEAD" "@GIT_DATA@/head-ref" COPYONLY)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(NOT HEAD_HASH)
|
||||||
|
file(READ "@GIT_DATA@/head-ref" HEAD_HASH LIMIT 1024)
|
||||||
|
string(STRIP "${HEAD_HASH}" HEAD_HASH)
|
||||||
|
endif()
|
|
@ -236,11 +236,14 @@ DTC_OVERLAY_FILE=\"dts1.overlay dts2.overlay\"")
|
||||||
set(CMAKE_C_COMPILER_FORCED 1)
|
set(CMAKE_C_COMPILER_FORCED 1)
|
||||||
set(CMAKE_CXX_COMPILER_FORCED 1)
|
set(CMAKE_CXX_COMPILER_FORCED 1)
|
||||||
|
|
||||||
|
include(${ZEPHYR_BASE}/cmake/GetGitRevisionDescription.cmake)
|
||||||
include(${ZEPHYR_BASE}/cmake/version.cmake)
|
include(${ZEPHYR_BASE}/cmake/version.cmake)
|
||||||
include(${ZEPHYR_BASE}/cmake/host-tools.cmake)
|
include(${ZEPHYR_BASE}/cmake/host-tools.cmake)
|
||||||
include(${ZEPHYR_BASE}/cmake/kconfig.cmake)
|
include(${ZEPHYR_BASE}/cmake/kconfig.cmake)
|
||||||
include(${ZEPHYR_BASE}/cmake/toolchain.cmake)
|
include(${ZEPHYR_BASE}/cmake/toolchain.cmake)
|
||||||
|
|
||||||
|
git_describe(BUILD_VERSION)
|
||||||
|
|
||||||
set(SOC_NAME ${CONFIG_SOC})
|
set(SOC_NAME ${CONFIG_SOC})
|
||||||
set(SOC_SERIES ${CONFIG_SOC_SERIES})
|
set(SOC_SERIES ${CONFIG_SOC_SERIES})
|
||||||
set(SOC_FAMILY ${CONFIG_SOC_FAMILY})
|
set(SOC_FAMILY ${CONFIG_SOC_FAMILY})
|
||||||
|
|
|
@ -31,16 +31,9 @@
|
||||||
#include <kswap.h>
|
#include <kswap.h>
|
||||||
|
|
||||||
/* kernel build timestamp items */
|
/* kernel build timestamp items */
|
||||||
|
|
||||||
#define BUILD_TIMESTAMP "BUILD: " __DATE__ " " __TIME__
|
#define BUILD_TIMESTAMP "BUILD: " __DATE__ " " __TIME__
|
||||||
|
|
||||||
#ifdef CONFIG_BUILD_TIMESTAMP
|
|
||||||
const char * const build_timestamp = BUILD_TIMESTAMP;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* boot banner items */
|
/* boot banner items */
|
||||||
|
|
||||||
static const unsigned int boot_delay;
|
|
||||||
#if defined(CONFIG_BOOT_DELAY) && CONFIG_BOOT_DELAY > 0
|
#if defined(CONFIG_BOOT_DELAY) && CONFIG_BOOT_DELAY > 0
|
||||||
#define BOOT_DELAY_BANNER " (delayed boot " \
|
#define BOOT_DELAY_BANNER " (delayed boot " \
|
||||||
STRINGIFY(CONFIG_BOOT_DELAY) "ms)"
|
STRINGIFY(CONFIG_BOOT_DELAY) "ms)"
|
||||||
|
@ -49,16 +42,19 @@ static const unsigned int boot_delay = CONFIG_BOOT_DELAY;
|
||||||
#define BOOT_DELAY_BANNER ""
|
#define BOOT_DELAY_BANNER ""
|
||||||
static const unsigned int boot_delay;
|
static const unsigned int boot_delay;
|
||||||
#endif
|
#endif
|
||||||
#define BOOT_BANNER "BOOTING ZEPHYR OS v" \
|
|
||||||
KERNEL_VERSION_STRING BOOT_DELAY_BANNER
|
#ifdef BUILD_VERSION
|
||||||
|
#define BOOT_BANNER "Booting Zephyr OS " \
|
||||||
|
STRINGIFY(BUILD_VERSION) BOOT_DELAY_BANNER
|
||||||
|
#else
|
||||||
|
#define BOOT_BANNER "Booting Zephyr OS " \
|
||||||
|
KERNEL_VERSION_STRING BOOT_DELAY_BANNER
|
||||||
|
#endif
|
||||||
|
|
||||||
#if !defined(CONFIG_BOOT_BANNER)
|
#if !defined(CONFIG_BOOT_BANNER)
|
||||||
#define PRINT_BOOT_BANNER() do { } while (0)
|
#define PRINT_BOOT_BANNER() do { } while (0)
|
||||||
#elif !defined(CONFIG_BUILD_TIMESTAMP)
|
|
||||||
#define PRINT_BOOT_BANNER() printk("***** " BOOT_BANNER " *****\n")
|
|
||||||
#else
|
#else
|
||||||
#define PRINT_BOOT_BANNER() \
|
#define PRINT_BOOT_BANNER() printk("***** " BOOT_BANNER " *****\n")
|
||||||
printk("***** " BOOT_BANNER " - %s *****\n", build_timestamp)
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* boot time measurement items */
|
/* boot time measurement items */
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue