summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPaul Eggleton <paul.eggleton@linux.intel.com>2010-12-16 16:25:13 +0000
committerRichard Purdie <rpurdie@linux.intel.com>2010-12-20 14:54:02 +0000
commit1993ca1f8790ff5bddc347ff22c78fd1c618739a (patch)
treefbe75d51a3e582e57069f305ff8518adab4d1aa2
parent2ec7757a48f298232bf9918a55b46503d5d21025 (diff)
downloadopenembedded-core-1993ca1f8790ff5bddc347ff22c78fd1c618739a.tar.gz
openembedded-core-1993ca1f8790ff5bddc347ff22c78fd1c618739a.tar.bz2
openembedded-core-1993ca1f8790ff5bddc347ff22c78fd1c618739a.zip
sanity.bbclass: allow minimisation of impact of more invasive sanity checks
Add a mechanism to avoid running more invasive checks every time bitbake is invoked. Adds a file in conf/ (i.e. under user's build directory) that tracks a new variable SANITY_VERSION (set in sanity.conf) as well as TMPDIR and SSTATE_DIR, allowing checks to be run when these are changed. Fixes [BUGID #562] Signed-off-by: Paul Eggleton <paul.eggleton@linux.intel.com>
-rw-r--r--meta/classes/sanity.bbclass48
-rw-r--r--meta/conf/sanity.conf1
2 files changed, 48 insertions, 1 deletions
diff --git a/meta/classes/sanity.bbclass b/meta/classes/sanity.bbclass
index 6dc4716af4..969cc2e59b 100644
--- a/meta/classes/sanity.bbclass
+++ b/meta/classes/sanity.bbclass
@@ -21,6 +21,18 @@ def check_conf_exists(fn, data):
return True
return False
+def check_sanity_sstate_dir_change():
+ # Sanity checks to be done when the value of SSTATE_DIR changes
+ return ""
+
+def check_sanity_tmpdir_change():
+ # Sanity checks to be done when the value of TMPDIR changes
+ return ""
+
+def check_sanity_version_change():
+ # Sanity checks to be done when SANITY_VERSION changes
+ return ""
+
def check_sanity(e):
from bb import note, error, data, __version__
@@ -173,10 +185,44 @@ def check_sanity(e):
if os.path.exists('%s/libc.so.6' % lib32path) and not os.path.exists('/usr/include/gnu/stubs-32.h'):
messages = messages + "You have a 32-bit libc, but no 32-bit headers. You must install the 32-bit libc headers.\n"
+ tmpdir = data.getVar('TMPDIR', e.data, True)
+ sstate_dir = data.getVar('SSTATE_DIR', e.data, True)
+
+ # Check saved sanity info
+ last_sanity_version = 0
+ last_tmpdir = ""
+ last_sstate_dir = ""
+ sanityverfile = 'conf/sanity_info'
+ if os.path.exists(sanityverfile):
+ f = file(sanityverfile, 'r')
+ for line in f:
+ if line.startswith('SANITY_VERSION'):
+ last_sanity_version = int(line.split()[1])
+ if line.startswith('TMPDIR'):
+ last_tmpdir = line.split()[1]
+ if line.startswith('SSTATE_DIR'):
+ last_sstate_dir = line.split()[1]
+
+ sanity_version = int(data.getVar('SANITY_VERSION', e.data, True) or 1)
+ if last_sanity_version < sanity_version:
+ messages = messages + check_sanity_version_change()
+ messages = messages + check_sanity_tmpdir_change()
+ messages = messages + check_sanity_sstate_dir_change()
+ else:
+ if last_tmpdir != tmpdir:
+ messages = messages + check_sanity_tmpdir_change()
+ if last_sstate_dir != sstate_dir:
+ messages = messages + check_sanity_sstate_dir_change()
+
+ if os.path.exists("conf"):
+ f = file(sanityverfile, 'w')
+ f.write("SANITY_VERSION %s\n" % sanity_version)
+ f.write("TMPDIR %s\n" % tmpdir)
+ f.write("SSTATE_DIR %s\n" % sstate_dir)
+
#
# Check that TMPDIR hasn't changed location since the last time we were run
#
- tmpdir = data.getVar('TMPDIR', e.data, True)
checkfile = os.path.join(tmpdir, "saved_tmpdir")
if os.path.exists(checkfile):
f = file(checkfile, "r")
diff --git a/meta/conf/sanity.conf b/meta/conf/sanity.conf
index eab7619022..1fbeb61aad 100644
--- a/meta/conf/sanity.conf
+++ b/meta/conf/sanity.conf
@@ -7,6 +7,7 @@ BB_MIN_VERSION = "1.8.10"
SANITY_ABIFILE = "${TMPDIR}/abi_version"
+SANITY_VERSION = "1"
POKY_CONF_VERSION = "1"
LAYER_CONF_VERSION = "3"
SITE_CONF_VERSION = "1"