summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rwxr-xr-xbitbake/bin/bitbake-runtask-strace8
-rw-r--r--meta/classes/image-swab.bbclass19
-rwxr-xr-xscripts/swabber-strace-attach30
3 files changed, 47 insertions, 10 deletions
diff --git a/bitbake/bin/bitbake-runtask-strace b/bitbake/bin/bitbake-runtask-strace
deleted file mode 100755
index 1741a84de2..0000000000
--- a/bitbake/bin/bitbake-runtask-strace
+++ /dev/null
@@ -1,8 +0,0 @@
1#!/bin/bash
2STRACE=`which strace`
3
4if [ ! -x "$STRACE" ]; then
5 bitbake-runtask $1 $2 $3 $4
6else
7 strace -f -o $TRACE_LOGFILE-$3.log -e trace=open,execve bitbake-runtask $1 $2 $3 $4
8fi
diff --git a/meta/classes/image-swab.bbclass b/meta/classes/image-swab.bbclass
index ec949ffe2e..b939ec4b45 100644
--- a/meta/classes/image-swab.bbclass
+++ b/meta/classes/image-swab.bbclass
@@ -2,7 +2,7 @@ HOST_DATA ?= "${TMPDIR}/host-contamination-data/"
2SWABBER_REPORT ?= "${LOG_DIR}/swabber/" 2SWABBER_REPORT ?= "${LOG_DIR}/swabber/"
3SWABBER_LOGS ?= "${LOG_DIR}/contamination-logs" 3SWABBER_LOGS ?= "${LOG_DIR}/contamination-logs"
4TRACE_LOGDIR ?= "${SWABBER_LOGS}/${PACKAGE_ARCH}" 4TRACE_LOGDIR ?= "${SWABBER_LOGS}/${PACKAGE_ARCH}"
5export TRACE_LOGFILE = "${TRACE_LOGDIR}/${PN}-${PV}" 5TRACE_LOGFILE = "${TRACE_LOGDIR}/${PN}-${PV}"
6 6
7SWAB_ORIG_TASK := "${BB_DEFAULT_TASK}" 7SWAB_ORIG_TASK := "${BB_DEFAULT_TASK}"
8BB_DEFAULT_TASK = "generate_swabber_report" 8BB_DEFAULT_TASK = "generate_swabber_report"
@@ -56,7 +56,22 @@ python() {
56 bb.data.setVarFlag('do_setscene', 'depends', " ".join(deps), d) 56 bb.data.setVarFlag('do_setscene', 'depends', " ".join(deps), d)
57 logdir = bb.data.expand("${TRACE_LOGDIR}", d) 57 logdir = bb.data.expand("${TRACE_LOGDIR}", d)
58 bb.utils.mkdirhier(logdir) 58 bb.utils.mkdirhier(logdir)
59 bb.data.setVar('BB_RUNTASK', 'bitbake-runtask-strace', d) 59 else:
60 bb.data.setVar('STRACEFUNC', '', d)
61}
62
63STRACEPID = "${@os.getpid()}"
64STRACEFUNC = "imageswab_attachstrace"
65
66do_configure[prefuncs] += "${STRACEFUNC}"
67do_compile[prefuncs] += "${STRACEFUNC}"
68
69imageswab_attachstrace () {
70 STRACE=`which strace`
71
72 if [ -x "$STRACE" ]; then
73 swabber-strace-attach "$STRACE -f -o ${TRACE_LOGFILE}-${BB_CURRENTTASK}.log -e trace=open,execve -p ${STRACEPID}" "${TRACE_LOGFILE}-traceattach-${BB_CURRENTTASK}.log"
74 fi
60} 75}
61 76
62do_generate_swabber_report () { 77do_generate_swabber_report () {
diff --git a/scripts/swabber-strace-attach b/scripts/swabber-strace-attach
new file mode 100755
index 0000000000..d4f80e4e91
--- /dev/null
+++ b/scripts/swabber-strace-attach
@@ -0,0 +1,30 @@
1#!/usr/bin/env python
2import os
3import sys
4
5# Detach from the controlling terminal and parent process by forking twice to daemonize ourselves,
6# then run the command passed as argv[1]. Send log data to argv[2].
7
8pid = os.fork()
9if (pid == 0):
10 os.setsid()
11 pid = os.fork()
12 if (pid != 0):
13 os._exit(0)
14else:
15 sys.exit()
16
17
18si = file(os.devnull, 'r')
19so = file(sys.argv[2], 'w')
20se = so
21
22# Replace those fds with our own
23os.dup2(si.fileno(), sys.stdin.fileno())
24os.dup2(so.fileno(), sys.stdout.fileno())
25os.dup2(se.fileno(), sys.stderr.fileno())
26
27ret = os.system(sys.argv[1])
28
29os._exit(ret)
30