From ef5291ac3887ba59c0e02f2d486cceaabf768b61 Mon Sep 17 00:00:00 2001 From: astrogeco <59618057+astrogeco@users.noreply.github.com> Date: Mon, 31 Aug 2020 15:54:53 -0400 Subject: [PATCH 1/2] Fix #830, Set Revision to 99 for development build The version number macros major, minor, and revision, are used in the HK telemetry which can lead to confusion. --- docs/src/cfs_versions.dox | 78 +++++++++++++++--------------- fsw/cfe-core/src/inc/cfe_version.h | 3 +- 2 files changed, 41 insertions(+), 40 deletions(-) diff --git a/docs/src/cfs_versions.dox b/docs/src/cfs_versions.dox index ab991dc55..f7b1a061d 100644 --- a/docs/src/cfs_versions.dox +++ b/docs/src/cfs_versions.dox @@ -1,94 +1,96 @@ /** \page cfsversions Version Numbers - +

Version Number Semantics

- + The version number is a sequence of four numbers, generally separated by dots when written. These are, in order, the Major number, the Minor number, the Revision number, and the Mission Revision number. Missions may modify the Mission Revision information as needed to suit their needs. - + It is important to note that Major, Minor, and Revision numbers are only updated upon official releases of tagged versions, \b NOT on development builds. We aim to follow the Semantic Versioning v2.0 specification with our versioning. - + The MAJOR number shall be incremented on release to indicate when there is a change to an API that may cause existing, correctly-written cFS components to stop working. It may also be incremented for a release that contains changes deemed to be of similar impact, even if there are no actual changes to the API. - + The MINOR number shall be incremented on release to indicate the addition of features to the API which do not break the existing code. It may also be incremented for a release that contains changes deemed to be of similar impact, even if there are no actual updates to the API. - - The REVISION number shall be incremented on changes that benefit from unique identification such as bug fixes or major documentation updates. The Revision number may also be updated if there are other changes contained within a release that make it desirable for applications to distinguish one release from another. - + + The REVISION number shall be incremented on changes that benefit from unique identification such as bug fixes or major documentation updates. + The Revision number may also be updated if there are other changes contained within a release that make it desirable for applications to distinguish one release from another. + WARNING: The revision number is set to the number 99 in development builds. To distinguish between development builds refer to the BUILD_NUMBER and BUILD_BASELINE detailed in the section "Identifying Development Builds". + The Major, Minor, and Revision numbers are provided in this header file as part of the API definition; this macro must expand to a simple integer value, so that it can be used in simple if directives by the macro preprocessor. - + The Mission Version number shall be set to zero in all officially released packages, and is entirely reserved for the use of the mission. The Mission Version is provided as a simple macro defined in the cfe_platform_cfg.h header file. - +

Version Number Flexibility

- + The major number may increment when there is no breaking change to the API, if the changes are significant enough to warrant the same level of attention as a breaking API change. - + The minor number may increment when there have been no augmentations to the API, if changes are as significant as additions to the public API. - + The revision numbers may increment in implementations where no actual implementation-specific code has changed, if there are other changes within the release with similar significance. - +

How and Where Defined

- + The Major, Minor, and Revision components of the version are provided as simple macros defined in the cfe_version.h header file as part of the API definition; these macros must expand to simple integer values, so that they can be used in simple if directives by the macro preprocessor. - + The Mission Version is provided as a simple macro defined in the cfe_platform_cfg.h header file. As delivered in official releases, these macros must expand to simple integer values, so that they can be used in simple macro preprocessor conditions, but delivered code should not prevent a mission from, for example, deciding that the Mission Version is actually a text string. - -

Identification of development builds

- - In order to distinguish between development versions, we also provide a BUILDNUMBER. - + +

Identifying Development Builds

+ + In order to distinguish between development versions, we also provide a BUILD_NUMBER. + The BUILD_NUMBER reflects the number of commits since the BUILD_BASELINE, a baseline git tag, for each particular component. The BUILD_NUMBER integer increases monotonically for a given development cycle. The BUILD_BASELINE identifies the current development cycle and is a git tag with format vX.Y.Z. The Codename used in the version string also refers to the current development cycle. When a new baseline tag and codename are created, the the BUILD_NUMBER resets to zero and begins increasing from a new baseline. - +

Templates for the version and version string

- + The following templates are the code to be used in cfe_version.h for either official releases or development builds. The apps and repositories follow the same pattern by replacing the CFE_ prefix with the appropriate name; for example, osal uses OS_, psp uses CFE_PSP_IMPL, and so on. - +

Template for Official Releases

- + \verbatim - /* Template for Development Builds \verbatim - /*! @brief Development Build Version Number. + /*! @brief Development Build Version Number. * Baseline git tag + Number of commits since baseline. @n * See cfs_versions.dox for format differences between development and release versions. */ - #define CFE_SRC_VERSION \ - CFE_BUILD_BASELINE CFE_STR(CFE_BUILD_NUMBER) + #define CFE_SRC_VERSION \ + CFE_BUILD_BASELINE CFE_STR(CFE_BUILD_NUMBER) - /*! @brief Development Build Version String. + /*! @brief Development Build Version String. * Reports the current development build's baseline, number, and name. Also includes a note about the latest official version. @n - * See cfs_versions.dox for format differences between development and release versions. - */ + * See cfs_versions.dox for format differences between development and release versions. + */ #define CFE_VERSION_STRING \ " cFE Development Build " \ CFE_SRC_VERSION " (Codename: CONSTELLATION_NAME)" /* Codename for current development */ \ ", Last Official Release: cfe vX.Y.Z" /* For full support please use this version */ - + \endverbatim - + **/ diff --git a/fsw/cfe-core/src/inc/cfe_version.h b/fsw/cfe-core/src/inc/cfe_version.h index f58244946..0629a5513 100644 --- a/fsw/cfe-core/src/inc/cfe_version.h +++ b/fsw/cfe-core/src/inc/cfe_version.h @@ -39,10 +39,9 @@ #define CFE_BUILD_BASELINE "v6.7.0" /*!< Development Build: git tag that is the base for the current development */ /* Version Macro Definitions */ - #define CFE_MAJOR_VERSION 6 /*!< @brief ONLY APPLY for OFFICIAL releases. Major version number. */ #define CFE_MINOR_VERSION 7 /*!< @brief ONLY APPLY for OFFICIAL releases. Minor version number. */ -#define CFE_REVISION 0 /*!< @brief ONLY APPLY for OFFICIAL releases. Revision version number. */ +#define CFE_REVISION 99 /*!< @brief ONLY APPLY for OFFICIAL releases. Revision version number. If set to 99 it indicates a development version. */ #define CFE_MISSION_REV 0 /*!< @brief ONLY USED by MISSION Implementations. Mission revision */ #define CFE_STR_HELPER(x) #x /*!< @brief Helper function to concatenate strings from integer macros */ From 27cc7df54a33da0a5d2b3996e10e3d0a533208c9 Mon Sep 17 00:00:00 2001 From: astrogeco <59618057+astrogeco@users.noreply.github.com> Date: Tue, 13 Oct 2020 19:13:06 -0400 Subject: [PATCH 2/2] Bump to v6.7.0+dev298 and update ReadMe --- README.md | 9 +++++++-- fsw/cfe-core/src/inc/cfe_version.h | 2 +- 2 files changed, 8 insertions(+), 3 deletions(-) diff --git a/README.md b/README.md index df22dc40d..03a3f197c 100644 --- a/README.md +++ b/README.md @@ -10,6 +10,11 @@ The detailed cFE user's guide can be viewed at + ### Development Build: 6.7.0+dev292 - Add missing include path to the target/h and wrn/coreip directory. @@ -27,7 +32,7 @@ Remove unrelated comment about CEXP (remnant from RTEMS). No more errors about m - All parameters to the stub function are registered in the context object, so the values will be available to hook functions. - The names of all parameters match the prototype/documentation, so hook functions that use name-based argument value retrieval will work. - Adds to table search path in `arch_build.cmake` -- Calls to OS_open() now use the OSAL-defined symbol, not the POSIX symbol. +- Calls to OS_open() now use the OSAL-defined symbol, not the POSIX symbol. - Defines new macros to report the build number and build baseline and new strings containing the version number of cFE and a combined string with the version number for OSAL, PSP, and CFE. - Allow explicitly setting of the processor ID in `targets.cmake`. The `TGTx_PROCESSOR_ID` setting will be passed to the final build/link of CFE core as the CPU ID. If unspecified, then the CMake index value is used instead (backward compatible). - `cmake` now detects conditions where no files were present to fulfill an config include file requirement and reports an error during `make prep` lists the files it checked for rather than generating an empty file. @@ -39,7 +44,7 @@ Remove unrelated comment about CEXP (remnant from RTEMS). No more errors about m - Added cFE User's Guide Reference to README.md - Removes old license - See - + ### Development Build: 6.7.20 - SB Unit use of the UT assert framework is closer to original design intent diff --git a/fsw/cfe-core/src/inc/cfe_version.h b/fsw/cfe-core/src/inc/cfe_version.h index 0629a5513..bf60dc94c 100644 --- a/fsw/cfe-core/src/inc/cfe_version.h +++ b/fsw/cfe-core/src/inc/cfe_version.h @@ -35,7 +35,7 @@ /* Development Build Macro Definitions */ -#define CFE_BUILD_NUMBER 292 /*!< Development Build: Number of commits since baseline */ +#define CFE_BUILD_NUMBER 298 /*!< Development Build: Number of commits since baseline */ #define CFE_BUILD_BASELINE "v6.7.0" /*!< Development Build: git tag that is the base for the current development */ /* Version Macro Definitions */