]> git.ipfire.org Git - thirdparty/openembedded/openembedded-core.git/commitdiff
base.bbclass: Fix way to check ccache path
authorChangqing Li <changqing.li@windriver.com>
Fri, 23 Dec 2022 03:38:40 +0000 (11:38 +0800)
committerSteve Sakoman <steve@sakoman.com>
Wed, 11 Jan 2023 16:07:36 +0000 (06:07 -1000)
The previous code had 2 issues:
1. make hosttools/ccache always link to host's ccache (/usr/bin/ccache)
even we have one buildtools
2. make hosttools/gcc etc, link to host's gcc event we have one
buildtools when keyword ccache in buildtools's path, eg:
/mnt/ccache/bin/buildtools

This patch is for fix above issues.

Signed-off-by: Changqing Li <changqing.li@windriver.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
(cherry picked from commit 1b7c81414cf252a7203d95703810a770184d7e4d)
Signed-off-by: Steve Sakoman <steve@sakoman.com>
meta/classes-global/base.bbclass

index 8203f54519276e85b306f5fef464b24299313f92..2d0e35517eba65130e9d9134f5225e0a4efc8306 100644 (file)
@@ -139,7 +139,7 @@ def setup_hosttools_dir(dest, toolsvar, d, fatal=True):
             # /usr/local/bin/ccache/gcc -> /usr/bin/ccache, then which(gcc)
             # would return /usr/local/bin/ccache/gcc, but what we need is
             # /usr/bin/gcc, this code can check and fix that.
-            if "ccache" in srctool:
+            if os.path.islink(srctool) and os.path.basename(os.readlink(srctool)) == 'ccache':
                 srctool = bb.utils.which(path, tool, executable=True, direction=1)
             if srctool:
                 os.symlink(srctool, desttool)