summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPhil Blundell <pb@pbcl.net>2013-04-24 13:07:47 +0100
committerRichard Purdie <richard.purdie@linuxfoundation.org>2013-04-29 14:43:50 +0100
commitd8c4f442c41bf3ac5e064630657cd3fa1b5c43b1 (patch)
tree706e9d153b42e9bf7ed4819180c5e9a7435949b1
parent443e75ee2c0e9a62df997aef24855bce54d39177 (diff)
downloadopenembedded-core-d8c4f442c41bf3ac5e064630657cd3fa1b5c43b1.tar.gz
openembedded-core-d8c4f442c41bf3ac5e064630657cd3fa1b5c43b1.tar.bz2
openembedded-core-d8c4f442c41bf3ac5e064630657cd3fa1b5c43b1.zip
sstate: Set umask to 002 before packaging runs
Otherwise we might end up creating directories under sstate-cache with whatever random umask has been selected for the task that we're trying to package. This would be a bad thing since it might result in losing group write access for newly created dirs, and/or losing group read access for the sstate files themselves. Signed-off-by: Phil Blundell <philb@gnu.org> Signed-off-by: Saul Wold <sgw@linux.intel.com>
-rw-r--r--meta/classes/sstate.bbclass4
1 files changed, 4 insertions, 0 deletions
diff --git a/meta/classes/sstate.bbclass b/meta/classes/sstate.bbclass
index 67ddc466ce..79d38304fd 100644
--- a/meta/classes/sstate.bbclass
+++ b/meta/classes/sstate.bbclass
@@ -532,7 +532,11 @@ python sstate_task_postfunc () {
sstate_install(shared_state, d)
for intercept in shared_state['interceptfuncs']:
bb.build.exec_func(intercept, d)
+ omask = os.umask(002)
+ if omask != 002:
+ bb.note("Using umask 002 (not %0o) for sstate packaging" % omask)
sstate_package(shared_state, d)
+ os.umask(omask)
}