From: Hongxu Jia <hongxu.jia@windriver.com>
To: Laurentiu Palcu <laurentiu.palcu@intel.com>,
Richard Purdie <richard.purdie@linuxfoundation.org>
Cc: openembedded-core@lists.openembedded.org
Subject: Re: [PATCH 2/3] buildhistory.bbclass: Fix dependency files creation
Date: Sat, 8 Mar 2014 16:23:22 +0800 [thread overview]
Message-ID: <531AD37A.9030300@windriver.com> (raw)
In-Reply-To: <20140307063553.GA21125@lpalcu-linux>
[-- Attachment #1: Type: text/plain, Size: 5430 bytes --]
On 03/07/2014 02:35 PM, Laurentiu Palcu wrote:
> On Thu, Mar 06, 2014 at 09:55:38PM +0000, Richard Purdie wrote:
>> On Wed, 2014-03-05 at 14:39 +0200, Laurentiu Palcu wrote:
>>> Call the new python routines.
>>>
>>> [YOCTO #5904]
>>>
>>> Signed-off-by: Laurentiu Palcu <laurentiu.palcu@intel.com>
>>> ---
>>> meta/classes/buildhistory.bbclass | 9 ++++++++-
>>> 1 file changed, 8 insertions(+), 1 deletion(-)
>>>
>>> diff --git a/meta/classes/buildhistory.bbclass b/meta/classes/buildhistory.bbclass
>>> index ef4135b..01b0082 100644
>>> --- a/meta/classes/buildhistory.bbclass
>>> +++ b/meta/classes/buildhistory.bbclass
>>> @@ -319,6 +319,12 @@ python buildhistory_list_installed() {
>>>
>>> with open(pkgs_list_file, 'w') as pkgs_list:
>>> pkgs_list.write(list_installed_packages(d, 'file'))
>>> +
>>> + pkgs_deps_file = os.path.join(d.getVar('WORKDIR', True),
>>> + "bh_installed_pkgs_deps.txt")
>>> +
>>> + with open(pkgs_deps_file, 'w') as pkgs_deps:
>>> + pkgs_deps.write(list_installed_packages(d, 'deps'))
>>> }
>>>
>>>
>>> @@ -338,7 +344,8 @@ buildhistory_get_installed() {
>>>
>>> # Produce dependency graph
>>> # First, quote each name to handle characters that cause issues for dot
>>> - rootfs_list_installed_depends | sed 's:\([^| ]*\):"\1":g' > $1/depends.tmp
>>> + cat ${WORKDIR}/bh_installed_pkgs_deps.txt | sed 's:\([^| ]*\):"\1":g' > $1/depends.tmp && \
>>> + rm ${WORKDIR}/bh_installed_pkgs_deps.txt
>>> # Change delimiter from pipe to -> and set style for recommend lines
>>> sed -i -e 's:|: -> :' -e 's:"\[REC\]":[style=dotted]:' -e 's:$:;:' $1/depends.tmp
>>> # Add header, sorted and de-duped contents and footer and then delete the temp file
>> With this patch, a bitbake core-image-minimal -c populate_sdk resulted
> No, not quite. The bug appears to be in
> RpmPM._pkg_translate_smart_to_oe(), which none of my patches touched.
>
> CCing Hongxu.
Hi Laurentiu and Richard,
The reason is pkg's arch was not found in the multilib arch list.
I could not reproduce the defect on my local build with these
patches applyed.
The attach a patch that add some trace code to see which
pkg's arch is not found in this situation.
//Hongxu
> laurentiu
>
>> in:
>>
>> ERROR: Error executing a python function in /media/build1/poky/meta/recipes-core/images/core-image-minimal.bb:
>>
>> The stack trace of python calls that resulted in this exception/failure was:
>> File: 'buildhistory_list_installed', lineno: 18, function: <module>
>> 0014: with open(pkgs_deps_file, 'w') as pkgs_deps:
>> 0015: pkgs_deps.write(list_installed_packages(d, 'deps'))
>> 0016:
>> 0017:
>> *** 0018:buildhistory_list_installed(d)
>> 0019:
>> File: 'buildhistory_list_installed', lineno: 9, function: buildhistory_list_installed
>> 0005: pkgs_list_file = os.path.join(d.getVar('WORKDIR', True),
>> 0006: "bh_installed_pkgs.txt")
>> 0007:
>> 0008: with open(pkgs_list_file, 'w') as pkgs_list:
>> *** 0009: pkgs_list.write(list_installed_packages(d, 'file'))
>> 0010:
>> 0011: pkgs_deps_file = os.path.join(d.getVar('WORKDIR', True),
>> 0012: "bh_installed_pkgs_deps.txt")
>> 0013:
>> File: '/media/build1/poky/meta/lib/oe/rootfs.py', lineno: 721, function: list_installed_packages
>> 0717: if img_type == "rpm":
>> 0718: return RpmPM(d,
>> 0719: rootfs_dir,
>> 0720: d.getVar('TARGET_VENDOR', True)
>> *** 0721: ).list_installed(format)
>> 0722: elif img_type == "ipk":
>> 0723: return OpkgPM(d,
>> 0724: rootfs_dir,
>> 0725: d.getVar("IPKGCONF_TARGET", True),
>> File: '/media/build1/poky/meta/lib/oe/package_manager.py', lineno: 854, function: list_installed
>> 0850: pkg = line.split()[0]
>> 0851: arch = line.split()[1]
>> 0852: ver = line.split()[2]
>> 0853: pkgorigin = line.split()[3]
>> *** 0854: new_pkg, new_arch = self._pkg_translate_smart_to_oe(pkg, arch)
>> 0855:
>> 0856: if format == "arch":
>> 0857: output.append('%s %s' % (new_pkg, new_arch))
>> 0858: elif format == "file":
>> File: '/media/build1/poky/meta/lib/oe/package_manager.py', lineno: 476, function: _pkg_translate_smart_to_oe
>> 0472:
>> 0473: if found == 1 and fixed_arch == fixed_cmp_arch:
>> 0474: break
>> 0475: #bb.note('%s, %s -> %s, %s' % (pkg, arch, new_pkg, new_arch))
>> *** 0476: return new_pkg, new_arch
>> 0477:
>> 0478: def _search_pkg_name_in_feeds(self, pkg, feed_archs):
>> 0479: for arch in feed_archs:
>> 0480: arch = arch.replace('-', '_')
>> Exception: UnboundLocalError: local variable 'new_arch' referenced before assignment
>>
>> ERROR: Function failed: buildhistory_list_installed
>> ERROR: Logfile of failure stored in: /media/build1/poky/build/tmp/work/qemux86-poky-linux/core-image-minimal/1.0-r0/temp/log.d
>>
>>
[-- Attachment #2: 0001-package_manager.py-add-trace-code-in-_pkg_translate_.patch --]
[-- Type: text/x-patch, Size: 1615 bytes --]
From 78f580e8f58ac852061b2b5879c4111607d20f45 Mon Sep 17 00:00:00 2001
From: Hongxu Jia <hongxu.jia@windriver.com>
Date: Sat, 8 Mar 2014 16:17:49 +0800
Subject: [PATCH] package_manager.py: add trace code in
_pkg_translate_smart_to_oe
There is a error while invoking RpmPM._pkg_translate_smart_to_oe(),
the reason is pkg's arch was not found in the multilib arch list.
Add some trace code to see which pkg's arch is not found.
Signed-off-by: Hongxu Jia <hongxu.jia@windriver.com>
---
meta/lib/oe/package_manager.py | 8 ++++++++
1 file changed, 8 insertions(+)
diff --git a/meta/lib/oe/package_manager.py b/meta/lib/oe/package_manager.py
index 76d0ce5..4cbf623 100644
--- a/meta/lib/oe/package_manager.py
+++ b/meta/lib/oe/package_manager.py
@@ -400,6 +400,7 @@ class RpmPM(PackageManager):
'''
def _pkg_translate_smart_to_oe(self, pkg, arch):
new_pkg = pkg
+ new_arch = ""
fixed_arch = arch.replace('_', '-')
found = 0
for mlib in self.ml_prefix_list:
@@ -426,6 +427,13 @@ class RpmPM(PackageManager):
if found == 1 and fixed_arch == fixed_cmp_arch:
break
#bb.note('%s, %s -> %s, %s' % (pkg, arch, new_pkg, new_arch))
+
+ if new_arch == "":
+ bb.warn('%s, %s is not found' % (pkg, arch))
+ for mlib in self.ml_prefix_list:
+ bb.warn('%s: %s' % (mlib, ' '.join(self.ml_prefix_list[mlib])))
+ new_arch = arch
+
return new_pkg, new_arch
def _search_pkg_name_in_feeds(self, pkg, feed_archs):
--
1.8.1.2
next prev parent reply other threads:[~2014-03-08 8:23 UTC|newest]
Thread overview: 12+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-03-05 12:39 [PATCH 0/3] Fix issue with unpopulated buildhistory depends files Laurentiu Palcu
2014-03-05 12:39 ` [PATCH 1/3] package_manager.py: make list_installed() list pkg dependencies too Laurentiu Palcu
2014-03-05 12:39 ` [PATCH 2/3] buildhistory.bbclass: Fix dependency files creation Laurentiu Palcu
2014-03-06 21:55 ` Richard Purdie
2014-03-07 6:35 ` Laurentiu Palcu
2014-03-08 8:23 ` Hongxu Jia [this message]
2014-03-10 7:46 ` Laurentiu Palcu
2014-03-26 9:15 ` Sarbu, Florin-Ionut (Florin)
2014-03-26 10:09 ` Laurentiu Palcu
2014-03-26 11:45 ` Florin Sarbu
2014-03-26 13:30 ` Laurentiu Palcu
2014-03-05 12:39 ` [PATCH 3/3] populate_sdk_*.bbclass: remove old rootfs_list_installed_depends() Laurentiu Palcu
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=531AD37A.9030300@windriver.com \
--to=hongxu.jia@windriver.com \
--cc=laurentiu.palcu@intel.com \
--cc=openembedded-core@lists.openembedded.org \
--cc=richard.purdie@linuxfoundation.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox