oe-debuginfod: add option for data storage

Storing the data files under $HOME can be unreliable if debuginfod
is used for several projects, especially if $HOME is shared
between machines.  We provide an option to save files under the
project directory.  The default behavior is unchanged.

(From OE-Core rev: e1e0cf82f559077e2a51447baf137086202c0c4a)

(From OE-Core rev: 24c0ab18045920bb5c1e965c0ea6d176fd6de234)

Signed-off-by: Joe Slater <joe.slater@windriver.com>
Signed-off-by: Deepesh Varatharajan <Deepesh.Varatharajan@windriver.com>
Signed-off-by: Steve Sakoman <steve@sakoman.com>
This commit is contained in:
Joe Slater
2025-07-16 02:01:02 -07:00
committed by Steve Sakoman
parent 15a4d0cfb1
commit 792d18b4cb

View File

@@ -15,14 +15,29 @@ scriptpath.add_bitbake_lib_path()
import bb.tinfoil
import subprocess
import argparse
if __name__ == "__main__":
p = argparse.ArgumentParser()
p.add_argument("-d", action='store_true', \
help="store debuginfod files in project sub-directory")
args = p.parse_args()
with bb.tinfoil.Tinfoil() as tinfoil:
tinfoil.prepare(config_only=True)
package_classes_var = "DEPLOY_DIR_" + tinfoil.config_data.getVar("PACKAGE_CLASSES").split()[0].replace("package_", "").upper()
feed_dir = tinfoil.config_data.getVar(package_classes_var, expand=True)
opts = [ '--verbose', '-R', '-U', feed_dir ]
if args.d:
fdir = os.path.join(os.getcwd(), 'oedid-files')
os.makedirs(fdir, exist_ok=True)
opts += [ '-d', os.path.join(fdir, 'did.sqlite') ]
subprocess.call(['bitbake', '-c', 'addto_recipe_sysroot', 'elfutils-native'])
subprocess.call(['oe-run-native', 'elfutils-native', 'debuginfod', '--verbose', '-R', '-U', feed_dir])
subprocess.call(['oe-run-native', 'elfutils-native', 'debuginfod'] + opts)
# we should not get here
print("\nTo use the debuginfod server please ensure that this variable PACKAGECONFIG:pn-elfutils-native = \"debuginfod libdebuginfod\" is set in the local.conf")