Merge pull request #14 from chutzimir/bin-kernel

Make it possible to run genkernel as an unprivileged user - useful to build a kernel from an ebuild
master
Fabio Erculiani 11 years ago
commit 391ba1c479

@ -4,6 +4,7 @@
get_KV() { get_KV() {
if [ "${KERNEL_SOURCES}" = '0' -a -e "${KERNCACHE}" ] if [ "${KERNEL_SOURCES}" = '0' -a -e "${KERNCACHE}" ]
then then
mkdir -p ${TEMP}
/bin/tar -xj -C ${TEMP} -f ${KERNCACHE} kerncache.config /bin/tar -xj -C ${TEMP} -f ${KERNCACHE} kerncache.config
if [ -e ${TEMP}/kerncache.config ] if [ -e ${TEMP}/kerncache.config ]
then then
@ -11,7 +12,7 @@ get_KV() {
PAT=`grep ^PATCHLEVEL\ \= ${TEMP}/kerncache.config | awk '{ print $3 };'` PAT=`grep ^PATCHLEVEL\ \= ${TEMP}/kerncache.config | awk '{ print $3 };'`
SUB=`grep ^SUBLEVEL\ \= ${TEMP}/kerncache.config | awk '{ print $3 };'` SUB=`grep ^SUBLEVEL\ \= ${TEMP}/kerncache.config | awk '{ print $3 };'`
EXV=`grep ^EXTRAVERSION\ \= ${TEMP}/kerncache.config | sed -e "s/EXTRAVERSION =//" -e "s/ //g"` EXV=`grep ^EXTRAVERSION\ \= ${TEMP}/kerncache.config | sed -e "s/EXTRAVERSION =//" -e "s/ //g"`
LOV=`grep ^CONFIG_LOCALVERSION\= ${TEMP}/kerncache.config | sed -e "s/CONFIG_LOCALVERSION=\"\(.*\)\"/\1/"` LOV=`grep ^CONFIG_LOCALVERSION\ \= ${TEMP}/kerncache.config | sed -e "s/CONFIG_LOCALVERSION =//" -e "s/ //g"`
KV=${VER}.${PAT}.${SUB}${EXV}${LOV} KV=${VER}.${PAT}.${SUB}${EXV}${LOV}
else else
gen_die "Could not find kerncache.config in the kernel cache! Exiting." gen_die "Could not find kerncache.config in the kernel cache! Exiting."
@ -59,8 +60,8 @@ get_KV() {
KV=${VER}.${PAT}.${SUB}${EXV}${LOV} KV=${VER}.${PAT}.${SUB}${EXV}${LOV}
else else
determine_config_file determine_config_file
LCV=`grep ^CONFIG_LOCALVERSION= "${KERNEL_CONFIG}" | sed -r -e "s/.*=\"(.*)\"/\1/"` LOV=`grep ^CONFIG_LOCALVERSION= "${KERNEL_CONFIG}" | sed -r -e "s/.*=\"(.*)\"/\1/"`
KV=${VER}.${PAT}.${SUB}${EXV}${LCV} KV=${VER}.${PAT}.${SUB}${EXV}${LOV}
fi fi
fi fi
} }

@ -273,7 +273,7 @@ append_iscsi(){
append_lvm(){ append_lvm(){
if [ -d "${TEMP}/initramfs-lvm-temp" ] if [ -d "${TEMP}/initramfs-lvm-temp" ]
then then
rm -r "${TEMP}/initramfs-lvm-temp/" rm -rf "${TEMP}/initramfs-lvm-temp/"
fi fi
cd ${TEMP} cd ${TEMP}
mkdir -p "${TEMP}/initramfs-lvm-temp"/{bin,sbin} mkdir -p "${TEMP}/initramfs-lvm-temp"/{bin,sbin}
@ -305,7 +305,7 @@ append_lvm(){
find . -print | cpio ${CPIO_ARGS} --append -F "${CPIO}" \ find . -print | cpio ${CPIO_ARGS} --append -F "${CPIO}" \
|| gen_die "compressing lvm cpio" || gen_die "compressing lvm cpio"
cd "${TEMP}" cd "${TEMP}"
rm -r "${TEMP}/initramfs-lvm-temp/" rm -rf "${TEMP}/initramfs-lvm-temp/"
} }
append_mdadm(){ append_mdadm(){
@ -690,6 +690,12 @@ append_ld_so_conf() {
# but we need to generate a valid ld.so.conf. So we extract the # but we need to generate a valid ld.so.conf. So we extract the
# current CPIO archive, run ldconfig -r against it and append the # current CPIO archive, run ldconfig -r against it and append the
# last bits. # last bits.
#
# We only do this if we are "root", because "ldconfig -r" requires
# root privileges to chroot. If we are not root we don't generate the
# ld.so.cache here, but expect that ldconfig would regenerate it when the
# machine boots.
if [[ $(id -u) == 0 && -z ${FAKED_MODE:-} ]]; then
local tmp_dir_ext="${tmp_dir}/extracted" local tmp_dir_ext="${tmp_dir}/extracted"
mkdir -p "${tmp_dir_ext}" mkdir -p "${tmp_dir_ext}"
mkdir -p "${tmp_dir}/etc" mkdir -p "${tmp_dir}/etc"
@ -709,6 +715,8 @@ append_ld_so_conf() {
|| gen_die "compressing ld.so.cache cpio" || gen_die "compressing ld.so.cache cpio"
cd "$(dirname "${tmp_dir}")" cd "$(dirname "${tmp_dir}")"
rm -rf "${tmp_dir}" rm -rf "${tmp_dir}"
fi
} }
print_list() print_list()

@ -95,6 +95,7 @@ gen_kerncache()
echo "PATCHLEVEL = ${PAT}" >> "${TEMP}/kerncache/kerncache.config" echo "PATCHLEVEL = ${PAT}" >> "${TEMP}/kerncache/kerncache.config"
echo "SUBLEVEL = ${SUB}" >> "${TEMP}/kerncache/kerncache.config" echo "SUBLEVEL = ${SUB}" >> "${TEMP}/kerncache/kerncache.config"
echo "EXTRAVERSION = ${EXV}" >> "${TEMP}/kerncache/kerncache.config" echo "EXTRAVERSION = ${EXV}" >> "${TEMP}/kerncache/kerncache.config"
echo "CONFIG_LOCALVERSION = ${LOV}" >> "${TEMP}/kerncache/kerncache.config"
mkdir -p "${TEMP}/kerncache/lib/modules/" mkdir -p "${TEMP}/kerncache/lib/modules/"
@ -143,7 +144,7 @@ gen_kerncache_extract_modules()
gen_kerncache_extract_config() gen_kerncache_extract_config()
{ {
if [ -e "${KERNCACHE}" ] if [ -e "${KERNCACHE}" -a "${SAVE_CONFIG}" = '1' ]
then then
print_info 1 'Extracting kerncache config to /etc/kernels' print_info 1 'Extracting kerncache config to /etc/kernels'
mkdir -p /etc/kernels mkdir -p /etc/kernels
@ -155,7 +156,7 @@ gen_kerncache_extract_config()
gen_kerncache_is_valid() gen_kerncache_is_valid()
{ {
KERNCACHE_IS_VALID=0 KERNCACHE_IS_VALID=0
if [ "${NO_KERNEL_SOURCES}" = '1' ] if [ "${KERNEL_SOURCES}" = '0' ]
then then
BUILD_KERNEL=0 BUILD_KERNEL=0

Loading…
Cancel
Save