2008-08-25 20:53:13 +00:00
|
|
|
#
|
|
|
|
# Creates a root filesystem out of rpm packages
|
|
|
|
#
|
|
|
|
|
2010-07-20 19:57:19 +00:00
|
|
|
ROOTFS_PKGMANAGE = "rpm"
|
2008-08-25 20:53:13 +00:00
|
|
|
ROOTFS_PKGMANAGE_BOOTSTRAP = "run-postinsts"
|
|
|
|
|
2010-07-20 19:57:19 +00:00
|
|
|
RPMOPTS="--dbpath /var/lib/rpm --define='_openall_before_chroot 1'"
|
|
|
|
RPM="${BUILD_ARCH}-${BUILD_OS}-rpm ${RPMOPTS}"
|
|
|
|
|
|
|
|
do_rootfs[depends] += "rpm-native:do_populate_sysroot"
|
2008-10-31 16:23:11 +00:00
|
|
|
|
|
|
|
# Needed for update-alternatives
|
2009-11-10 14:55:23 +00:00
|
|
|
do_rootfs[depends] += "opkg-native:do_populate_sysroot"
|
2008-10-31 16:23:11 +00:00
|
|
|
|
2008-08-25 20:53:13 +00:00
|
|
|
do_rootfs[recrdeptask] += "do_package_write_rpm"
|
|
|
|
|
2010-07-20 19:57:19 +00:00
|
|
|
AWKPOSTINSTSCRIPT = "${POKYBASE}/scripts/rootfs_rpm-extract-postinst.awk"
|
2008-09-03 23:22:06 +00:00
|
|
|
|
2008-10-07 16:47:22 +00:00
|
|
|
RPM_PREPROCESS_COMMANDS = ""
|
2010-07-20 19:57:19 +00:00
|
|
|
RPM_POSTPROCESS_COMMANDS = ""
|
2008-10-07 16:21:25 +00:00
|
|
|
|
2008-08-25 20:53:13 +00:00
|
|
|
fakeroot rootfs_rpm_do_rootfs () {
|
|
|
|
set -x
|
2008-10-07 16:47:22 +00:00
|
|
|
|
|
|
|
${RPM_PREPROCESS_COMMANDS}
|
2008-08-25 20:53:13 +00:00
|
|
|
|
2010-07-20 19:57:19 +00:00
|
|
|
# Setup base system configuration
|
2008-08-25 20:53:13 +00:00
|
|
|
mkdir -p ${IMAGE_ROOTFS}/etc/rpm/
|
2008-10-07 13:43:07 +00:00
|
|
|
echo "${TARGET_ARCH}-linux" >${IMAGE_ROOTFS}/etc/rpm/platform
|
2008-08-25 20:53:13 +00:00
|
|
|
|
2010-07-20 19:57:19 +00:00
|
|
|
# Instantiate the dep solver database
|
|
|
|
mkdir -p ${IMAGE_ROOTFS}/var/lib/rpm_solver
|
2008-10-02 19:02:39 +00:00
|
|
|
|
2010-07-20 19:57:19 +00:00
|
|
|
# Generate dep_solver manifest
|
|
|
|
cat /dev/null > ${IMAGE_ROOTFS}/var/lib/rpm_solver/dep_solver.manifest
|
|
|
|
echo "# Dynamically generated install manifest -- avoid small file bug" >> ${IMAGE_ROOTFS}/var/lib/rpm_solver/dep_solver.manifest
|
2008-10-02 15:22:10 +00:00
|
|
|
for arch in ${PACKAGE_ARCHS}; do
|
2010-07-20 19:57:19 +00:00
|
|
|
[ -d ${DEPLOY_DIR_RPM}/$arch ] && find ${DEPLOY_DIR_RPM}/$arch -type f >> ${IMAGE_ROOTFS}/var/lib/rpm_solver/dep_solver.manifest
|
2008-10-02 15:22:10 +00:00
|
|
|
done
|
2010-07-20 19:57:19 +00:00
|
|
|
|
|
|
|
${RPM} --root ${IMAGE_ROOTFS} --dbpath /var/lib/rpm_solver --initdb
|
|
|
|
${RPM} --root ${IMAGE_ROOTFS} --dbpath /var/lib/rpm_solver -Uhv ${IMAGE_ROOTFS}/var/lib/rpm_solver/dep_solver.manifest --justdb --nodeps --noparentdirs --nolinktos
|
2008-10-02 15:22:10 +00:00
|
|
|
|
2010-07-20 19:57:19 +00:00
|
|
|
# Resolve Dependencies and Install
|
2008-08-25 20:53:13 +00:00
|
|
|
if [ x${TARGET_OS} = "xlinux" ] || [ x${TARGET_OS} = "xlinux-gnueabi" ] ; then
|
|
|
|
if [ ! -z "${LINGUAS_INSTALL}" ]; then
|
|
|
|
for i in ${LINGUAS_INSTALL}; do
|
2010-07-20 19:57:19 +00:00
|
|
|
: # Do not support locales yet
|
2008-08-25 20:53:13 +00:00
|
|
|
done
|
|
|
|
fi
|
|
|
|
fi
|
2010-07-20 19:57:19 +00:00
|
|
|
|
2008-08-25 20:53:13 +00:00
|
|
|
if [ ! -z "${PACKAGE_INSTALL}" ]; then
|
2010-07-20 19:57:19 +00:00
|
|
|
# Create the install manifest, starting with the PACKAGE_INSTALL packages
|
|
|
|
touch ${IMAGE_ROOTFS}/install.manifest
|
|
|
|
for each in ${PACKAGE_INSTALL} ; do
|
|
|
|
# Map package name to filename
|
|
|
|
pkg_name=$(${RPM} --root ${IMAGE_ROOTFS} --dbpath /var/lib/rpm_solver -q --qf "%{NAME}-%{VERSION}-%{RELEASE}.%{ARCH}" $each)
|
|
|
|
echo Processing "$each $pkg_name"
|
|
|
|
# Map filename to full path
|
|
|
|
[ -n "$pkg_name" ] && grep "/"$pkg_name ${IMAGE_ROOTFS}/var/lib/rpm_solver/dep_solver.manifest >> ${IMAGE_ROOTFS}/install.manifest
|
|
|
|
done
|
2008-08-25 20:53:13 +00:00
|
|
|
fi
|
|
|
|
|
2010-07-20 19:57:19 +00:00
|
|
|
# Attempt to resolve dependencies and add missing packages to the install.manifest
|
|
|
|
# Loop over the resolution until there is nothing else to resolve...
|
|
|
|
# We log the solver.logs so we can track the dep solver process for debugging...
|
|
|
|
resolver=1
|
|
|
|
while [ $resolver -gt 0 ]; do
|
|
|
|
(${RPM} --root ${IMAGE_ROOTFS} \
|
|
|
|
--define '_solve_dbpath /var/lib/rpm_solver' --define '_solve_name_fmt add:%{___NVRA}.rpm' --aid \
|
|
|
|
-Uhv --noparentdirs --nolinktos --test ${IMAGE_ROOTFS}/install.manifest > ${IMAGE_ROOTFS}/solver.log.$resolver 2>&1 || :)
|
|
|
|
|
|
|
|
resolve_continue=false
|
|
|
|
for each in `cat ${IMAGE_ROOTFS}/solver.log.$resolver | grep "add:" | cut -d : -f 2` ; do
|
|
|
|
pkg_name=$each
|
|
|
|
echo Processing "$each $pkg_name"
|
|
|
|
# Map filename to full path
|
|
|
|
[ -n "$pkg_name" ] && grep "/"$pkg_name ${IMAGE_ROOTFS}/var/lib/rpm_solver/dep_solver.manifest >> ${IMAGE_ROOTFS}/install.manifest
|
|
|
|
resolve_continue=true
|
|
|
|
done
|
|
|
|
if [ "$resolve_continue" == "true" ]; then
|
|
|
|
resolver=$(expr $resolver + 1)
|
|
|
|
else
|
|
|
|
resolver=0
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
|
|
|
# Attempt install
|
|
|
|
${RPM} --root ${IMAGE_ROOTFS} \
|
|
|
|
--define '_solve_dbpath /var/lib/rpm_solver' --define '_solve_name_fmt add:%{___NVRA}.rpm' --aid \
|
|
|
|
-Uhv --noparentdirs --nolinktos --noscripts ${IMAGE_ROOTFS}/install.manifest
|
|
|
|
|
2008-11-06 16:23:32 +00:00
|
|
|
if [ ! -z "${PACKAGE_INSTALL_ATTEMPTONLY}" ]; then
|
2010-07-20 19:57:19 +00:00
|
|
|
: # fakechroot yum ${YUMARGS} -y install ${PACKAGE_INSTALL_ATTEMPTONLY} > ${WORKDIR}/temp/log.do_rootfs-attemptonly.${PID} || true
|
2008-11-06 16:23:32 +00:00
|
|
|
fi
|
|
|
|
|
2008-09-08 11:19:23 +00:00
|
|
|
# Add any recommended packages to the image
|
|
|
|
# (added as an extra script since yum itself doesn't support this)
|
2010-07-20 19:57:19 +00:00
|
|
|
: # yum-install-recommends.py ${IMAGE_ROOTFS} "fakechroot yum ${YUMARGS} -y install"
|
2008-09-04 21:52:34 +00:00
|
|
|
|
2008-09-03 23:22:06 +00:00
|
|
|
export D=${IMAGE_ROOTFS}
|
|
|
|
export OFFLINE_ROOT=${IMAGE_ROOTFS}
|
|
|
|
export IPKG_OFFLINE_ROOT=${IMAGE_ROOTFS}
|
|
|
|
export OPKG_OFFLINE_ROOT=${IMAGE_ROOTFS}
|
2008-08-25 20:53:13 +00:00
|
|
|
|
|
|
|
#mkdir -p ${IMAGE_ROOTFS}/etc/opkg/
|
|
|
|
#grep "^arch" ${IPKGCONF_TARGET} >${IMAGE_ROOTFS}/etc/opkg/arch.conf
|
|
|
|
|
|
|
|
${ROOTFS_POSTINSTALL_COMMAND}
|
2008-09-03 23:22:06 +00:00
|
|
|
|
|
|
|
mkdir -p ${IMAGE_ROOTFS}/etc/rpm-postinsts/
|
2010-07-20 19:57:19 +00:00
|
|
|
${RPM} --root ${IMAGE_ROOTFS} -qa --queryformat 'Name: %{NAME}\n' --scripts > ${IMAGE_ROOTFS}/etc/rpm-postinsts/combined
|
2008-09-03 23:22:06 +00:00
|
|
|
awk -f ${AWKPOSTINSTSCRIPT} < ${IMAGE_ROOTFS}/etc/rpm-postinsts/combined
|
|
|
|
rm ${IMAGE_ROOTFS}/etc/rpm-postinsts/combined
|
|
|
|
|
|
|
|
for i in ${IMAGE_ROOTFS}/etc/rpm-postinsts/*.sh; do
|
|
|
|
if [ -f $i ] && sh $i; then
|
2008-09-04 21:52:34 +00:00
|
|
|
# rm $i
|
|
|
|
mv $i $i.done
|
2008-09-03 23:22:06 +00:00
|
|
|
fi
|
|
|
|
done
|
2008-08-25 20:53:13 +00:00
|
|
|
|
2008-09-04 21:52:34 +00:00
|
|
|
install -d ${IMAGE_ROOTFS}/${sysconfdir}/rcS.d
|
|
|
|
# Stop $i getting expanded below...
|
|
|
|
i=\$i
|
|
|
|
cat > ${IMAGE_ROOTFS}${sysconfdir}/rcS.d/S98configure << EOF
|
|
|
|
#!/bin/sh
|
|
|
|
for i in /etc/rpm-postinsts/*.sh; do
|
|
|
|
echo "Running postinst $i..."
|
|
|
|
if [ -f $i ] && sh $i; then
|
|
|
|
# rm $i
|
|
|
|
mv $i $i.done
|
|
|
|
else
|
|
|
|
echo "ERROR: postinst $i failed."
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
rm -f ${sysconfdir}/rcS.d/S98configure
|
|
|
|
EOF
|
|
|
|
chmod 0755 ${IMAGE_ROOTFS}${sysconfdir}/rcS.d/S98configure
|
|
|
|
|
2008-08-25 20:53:13 +00:00
|
|
|
install -d ${IMAGE_ROOTFS}/${sysconfdir}
|
|
|
|
echo ${BUILDNAME} > ${IMAGE_ROOTFS}/${sysconfdir}/version
|
|
|
|
|
2008-10-07 16:21:25 +00:00
|
|
|
${RPM_POSTPROCESS_COMMANDS}
|
2008-08-25 20:53:13 +00:00
|
|
|
${ROOTFS_POSTPROCESS_COMMAND}
|
|
|
|
|
|
|
|
rm -rf ${IMAGE_ROOTFS}/var/cache2/
|
|
|
|
rm -rf ${IMAGE_ROOTFS}/var/run2/
|
|
|
|
rm -rf ${IMAGE_ROOTFS}/var/log2/
|
|
|
|
|
2008-10-03 15:23:05 +00:00
|
|
|
# remove lock files
|
|
|
|
rm -f ${IMAGE_ROOTFS}/var/lib/rpm/__db.*
|
|
|
|
|
2010-07-20 19:57:19 +00:00
|
|
|
# remove resolver files and manifests
|
|
|
|
rm -f ${IMAGE_ROOTFS}/install.manifest
|
|
|
|
rm -f ${IMAGE_ROOTFS}/solver.log.*
|
|
|
|
|
|
|
|
# Remove resolver DB
|
|
|
|
rm -rf ${IMAGE_ROOTFS}/var/lib/rpm_solver
|
2008-10-07 15:34:55 +00:00
|
|
|
|
2009-11-16 10:51:24 +00:00
|
|
|
log_check rootfs
|
2008-08-25 20:53:13 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
rootfs_rpm_log_check() {
|
|
|
|
target="$1"
|
|
|
|
lf_path="$2"
|
|
|
|
|
|
|
|
lf_txt="`cat $lf_path`"
|
|
|
|
for keyword_die in "Cannot find package" "exit 1" ERR Fail
|
2009-11-16 10:51:24 +00:00
|
|
|
do
|
2008-08-25 20:53:13 +00:00
|
|
|
if (echo "$lf_txt" | grep -v log_check | grep "$keyword_die") >/dev/null 2>&1
|
|
|
|
then
|
|
|
|
echo "log_check: There were error messages in the logfile"
|
|
|
|
echo -e "log_check: Matched keyword: [$keyword_die]\n"
|
|
|
|
echo "$lf_txt" | grep -v log_check | grep -C 5 -i "$keyword_die"
|
|
|
|
echo ""
|
2009-11-16 10:51:24 +00:00
|
|
|
do_exit=1
|
2008-08-25 20:53:13 +00:00
|
|
|
fi
|
|
|
|
done
|
|
|
|
test "$do_exit" = 1 && exit 1
|
|
|
|
true
|
|
|
|
}
|
|
|
|
|
|
|
|
remove_packaging_data_files() {
|
|
|
|
rm -rf ${IMAGE_ROOTFS}/usr/lib/opkg/
|
|
|
|
}
|
|
|
|
|
|
|
|
install_all_locales() {
|
|
|
|
|
|
|
|
PACKAGES_TO_INSTALL=""
|
|
|
|
|
|
|
|
INSTALLED_PACKAGES=`grep ^Package: ${IMAGE_ROOTFS}${libdir}/opkg/status |sed "s/^Package: //"|egrep -v -- "(-locale-|-dev$|-doc$|^kernel|^glibc|^ttf|^task|^perl|^python)"`
|
|
|
|
|
|
|
|
for pkg in $INSTALLED_PACKAGES
|
|
|
|
do
|
|
|
|
for lang in ${IMAGE_LOCALES}
|
|
|
|
do
|
|
|
|
if [ `opkg-cl ${IPKG_ARGS} info $pkg-locale-$lang | wc -l` -gt 2 ]
|
|
|
|
then
|
|
|
|
PACKAGES_TO_INSTALL="$PACKAGES_TO_INSTALL $pkg-locale-$lang"
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
done
|
|
|
|
if [ "$PACKAGES_TO_INSTALL" != "" ]
|
|
|
|
then
|
|
|
|
opkg-cl ${IPKG_ARGS} install $PACKAGES_TO_INSTALL
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2008-10-07 16:47:22 +00:00
|
|
|
python () {
|
|
|
|
if bb.data.getVar('BUILD_IMAGES_FROM_FEEDS', d, True):
|
|
|
|
flags = bb.data.getVarFlag('do_rootfs', 'recrdeptask', d)
|
|
|
|
flags = flags.replace("do_package_write_rpm", "")
|
|
|
|
flags = flags.replace("do_deploy", "")
|
2009-11-10 14:55:23 +00:00
|
|
|
flags = flags.replace("do_populate_sysroot", "")
|
2008-10-07 16:47:22 +00:00
|
|
|
bb.data.setVarFlag('do_rootfs', 'recrdeptask', flags, d)
|
|
|
|
bb.data.setVar('RPM_PREPROCESS_COMMANDS', "rpm_insert_feed_uris", d)
|
|
|
|
bb.data.setVar('RPM_POSTPROCESS_COMMANDS', '', d)
|
|
|
|
}
|