xref: /openbmc/openbmc/meta-phosphor/recipes-core/os-release/os-release.bbappend (revision bec4ebc22c43c1ff5c3fddb820d44a88bd3aebf0)
1# WARNING!
2#
3# These modifications to os-release disable the bitbake parse
4# cache (for the os-release recipe only).  Before copying
5# and pasting into another recipe ensure it is understood
6# what that means!
7
8OS_RELEASE_ROOTPATH ?= "${COREBASE}"
9
10def run_git(d, cmd):
11    try:
12        oeroot = d.getVar('OS_RELEASE_ROOTPATH', True)
13        return bb.process.run(("export PSEUDO_DISABLED=1; " +
14                               "git --work-tree %s --git-dir %s/.git %s")
15            % (oeroot, oeroot, cmd))[0].strip('\n')
16    except Exception as e:
17        bb.warn("Unexpected exception from 'git' call: %s" % e)
18        pass
19
20# DISTRO_VERSION can be overridden by a bbappend or config, so it must be a
21# weak override.  But, when a variable is weakly overridden the definition
22# and not the contents are used in the task-hash (for sstate reuse).  We need
23# a strong variable in the vardeps chain for do_compile so that we get the
24# contents of the 'git describe --dirty' call.  Create a strong/immediate
25# indirection via PHOSPHOR_OS_RELEASE_DISTRO_VERSION.
26PHOSPHOR_OS_RELEASE_DISTRO_VERSION := "${@run_git(d, 'describe --dirty')}"
27DISTRO_VERSION ??= "${PHOSPHOR_OS_RELEASE_DISTRO_VERSION}"
28
29VERSION = "${@'-'.join(d.getVar('VERSION_ID').split('-')[0:2])}"
30
31OPENBMC_TARGET_MACHINE = "${MACHINE}"
32
33OS_RELEASE_FIELDS:append = " BUILD_ID OPENBMC_TARGET_MACHINE EXTENDED_VERSION"
34
35# Ensure the git commands run every time bitbake is invoked.
36BB_DONT_CACHE = "1"
37
38# Make os-release available to other recipes.
39SYSROOT_DIRS:append = " ${sysconfdir}"
40