mirror of
https://git.yoctoproject.org/poky
synced 2026-02-06 08:48:45 +01:00
For beagleboard platform, the PACKAGE_ARCH for certain recipes is "armv7a-vfp-neon", however, the architecture label in RPM file name is "armv7a" due to a potential bug in RPM backend. This commit is a workaround to make Hob work in this case. (From OE-Core rev: 00bd4589b21fe3a716ff2732ea55651c4abd77e4) Signed-off-by: Dongxiao Xu <dongxiao.xu@intel.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
47 lines
3.1 KiB
Plaintext
47 lines
3.1 KiB
Plaintext
python packageinfo_handler () {
|
|
if isinstance(e, bb.event.RequestPackageInfo):
|
|
import oe.packagedata
|
|
pkginfolist = []
|
|
tmpdir = e.data.getVar('TMPDIR', True)
|
|
target_vendor = e.data.getVar('TARGET_VENDOR', True)
|
|
target_os = e.data.getVar('TARGET_OS', True)
|
|
package_archs = e.data.getVar('PACKAGE_ARCHS', True)
|
|
packaging = e.data.getVar('PACKAGE_CLASSES', True).split()[0].split('_')[1]
|
|
deploy_dir = e.data.getVar('DEPLOY_DIR', True) + '/' + packaging
|
|
for arch in package_archs.split():
|
|
pkgdata_dir = tmpdir + '/pkgdata/' + arch + target_vendor + '-' + target_os + '/runtime/'
|
|
if os.path.exists(pkgdata_dir):
|
|
for root, dirs, files in os.walk(pkgdata_dir):
|
|
for pkgname in files:
|
|
if pkgname.endswith('.packaged'):
|
|
continue
|
|
sdata = oe.packagedata.read_pkgdatafile(root + pkgname)
|
|
sdata['PKG'] = pkgname
|
|
pkgrename = sdata['PKG_%s' % pkgname]
|
|
pkgv = sdata['PKGV'].replace('-', '+')
|
|
pkgr = sdata['PKGR']
|
|
# We found there are some renaming issue with certain architecture.
|
|
# For example, armv7a-vfp-neon, it will use armv7a in the rpm file. This is the workaround for it.
|
|
arch_tmp = arch.split('-')[0]
|
|
if os.path.exists(deploy_dir + '/' + arch + '/' + \
|
|
pkgname + '-' + pkgv + '-' + pkgr + '.' + arch + '.' + packaging) or \
|
|
os.path.exists(deploy_dir + '/' + arch + '/' + \
|
|
pkgname + '-' + pkgv + '-' + pkgr + '.' + arch_tmp + '.' + packaging) or \
|
|
os.path.exists(deploy_dir + '/' + arch + '/' + \
|
|
pkgrename + '-' + pkgv + '-' + pkgr + '.' + arch + '.' + packaging) or \
|
|
os.path.exists(deploy_dir + '/' + arch + '/' + \
|
|
pkgrename + '-' + pkgv + '-' + pkgr + '.' + arch_tmp + '.' + packaging) or \
|
|
os.path.exists(deploy_dir + '/' + arch + '/' + \
|
|
pkgname + '_' + pkgv + '-' + pkgr + '_' + arch + '.' + packaging) or \
|
|
os.path.exists(deploy_dir + '/' + arch + '/' + \
|
|
pkgname + '_' + pkgv + '-' + pkgr + '_' + arch_tmp + '.' + packaging) or \
|
|
os.path.exists(deploy_dir + '/' + arch + '/' + \
|
|
pkgrename + '_' + pkgv + '-' + pkgr + '_' + arch + '.' + packaging) or \
|
|
os.path.exists(deploy_dir + '/' + arch + '/' + \
|
|
pkgrename + '_' + pkgv + '-' + pkgr + '_' + arch_tmp + '.' + packaging):
|
|
pkginfolist.append(sdata)
|
|
bb.event.fire(bb.event.PackageInfo(pkginfolist), e.data)
|
|
}
|
|
|
|
addhandler packageinfo_handler
|