summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRichard Purdie <richard.purdie@linuxfoundation.org>2012-02-23 10:12:48 +0000
committerRichard Purdie <richard.purdie@linuxfoundation.org>2012-02-23 22:52:22 +0000
commit26882fdd6718b4f5ceb970dd9e1e7ee8c9273f17 (patch)
treee674f8e17c3178eb575d09577037e2bfc8c93f21
parent77988c32f1c9b3eb9248ac6eb296fb8f4c833752 (diff)
downloadpoky-26882fdd6718b4f5ceb970dd9e1e7ee8c9273f17.tar.gz
sstatesig.py: Move package exclusion list to the layer config
its desireable for other layers to be able to append to the list of packages with 'safe ABI's which are excluded from the sstate signatures. I can't emphasise enough how careful you need to be with this list, anything excluded here needs to be things which don't change interface and are consistent between different machines. (From OE-Core rev: 5adef35691a956c3071c0a1ed1caf6b58d1ec5a1) Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
-rw-r--r--meta/conf/layer.conf1
-rw-r--r--meta/lib/oe/sstatesig.py10
2 files changed, 7 insertions, 4 deletions
diff --git a/meta/conf/layer.conf b/meta/conf/layer.conf
index ad9540586c..c0c2930f0d 100644
--- a/meta/conf/layer.conf
+++ b/meta/conf/layer.conf
@@ -18,3 +18,4 @@ PATH := "${PATH}:${COREBASE}/scripts"
18 18
19QEMUIMAGETESTS := "${COREBASE}/scripts/qemuimage-tests" 19QEMUIMAGETESTS := "${COREBASE}/scripts/qemuimage-tests"
20 20
21SIGGEN_EXCLUDERECIPES_ABISAFE = "sysvinit-inittab shadow-securetty opkg-config-base netbase formfactor xserver-xf86-config pointercal base-files"
diff --git a/meta/lib/oe/sstatesig.py b/meta/lib/oe/sstatesig.py
index 5a64882fba..7b80c18b63 100644
--- a/meta/lib/oe/sstatesig.py
+++ b/meta/lib/oe/sstatesig.py
@@ -1,6 +1,6 @@
1import bb.siggen 1import bb.siggen
2 2
3def sstate_rundepfilter(fn, recipename, task, dep, depname, dataCache): 3def sstate_rundepfilter(siggen, fn, recipename, task, dep, depname, dataCache):
4 # Return True if we should keep the dependency, False to drop it 4 # Return True if we should keep the dependency, False to drop it
5 def isNative(x): 5 def isNative(x):
6 return x.endswith("-native") 6 return x.endswith("-native")
@@ -30,7 +30,7 @@ def sstate_rundepfilter(fn, recipename, task, dep, depname, dataCache):
30 return False 30 return False
31 31
32 # Exclude well defined machine specific configurations which don't change ABI 32 # Exclude well defined machine specific configurations which don't change ABI
33 if depname in ['sysvinit-inittab', 'shadow-securetty', 'opkg-config-base', 'netbase', 'formfactor', 'xserver-xf86-config', 'pointercal', 'base-files']: 33 if depname in siggen.abisaferecipes:
34 return False 34 return False
35 35
36 # Kernel modules are well namespaced. We don't want to depend on the kernel's checksum 36 # Kernel modules are well namespaced. We don't want to depend on the kernel's checksum
@@ -50,16 +50,18 @@ def sstate_rundepfilter(fn, recipename, task, dep, depname, dataCache):
50class SignatureGeneratorOEBasic(bb.siggen.SignatureGeneratorBasic): 50class SignatureGeneratorOEBasic(bb.siggen.SignatureGeneratorBasic):
51 name = "OEBasic" 51 name = "OEBasic"
52 def init_rundepcheck(self, data): 52 def init_rundepcheck(self, data):
53 self.abisaferecipes = (data.getVar("SIGGEN_EXCLUDERECIPES_ABISAFE", True) or "").split()
53 pass 54 pass
54 def rundep_check(self, fn, recipename, task, dep, depname, dataCache = None): 55 def rundep_check(self, fn, recipename, task, dep, depname, dataCache = None):
55 return sstate_rundepfilter(fn, recipename, task, dep, depname, dataCache) 56 return sstate_rundepfilter(self, fn, recipename, task, dep, depname, dataCache)
56 57
57class SignatureGeneratorOEBasicHash(bb.siggen.SignatureGeneratorBasicHash): 58class SignatureGeneratorOEBasicHash(bb.siggen.SignatureGeneratorBasicHash):
58 name = "OEBasicHash" 59 name = "OEBasicHash"
59 def init_rundepcheck(self, data): 60 def init_rundepcheck(self, data):
61 self.abisaferecipes = (data.getVar("SIGGEN_EXCLUDERECIPES_ABISAFE", True) or "").split()
60 pass 62 pass
61 def rundep_check(self, fn, recipename, task, dep, depname, dataCache = None): 63 def rundep_check(self, fn, recipename, task, dep, depname, dataCache = None):
62 return sstate_rundepfilter(fn, recipename, task, dep, depname, dataCache) 64 return sstate_rundepfilter(self, fn, recipename, task, dep, depname, dataCache)
63 65
64# Insert these classes into siggen's namespace so it can see and select them 66# Insert these classes into siggen's namespace so it can see and select them
65bb.siggen.SignatureGeneratorOEBasic = SignatureGeneratorOEBasic 67bb.siggen.SignatureGeneratorOEBasic = SignatureGeneratorOEBasic