Adding user-specified /linuxrc support; bug #66198.

git-svn-id: svn+ssh://svn.gentoo.org/var/svnroot/genkernel/trunk@148 67a159dc-881f-0410-a524-ba9dfbe2cb84
cleanup-cruft
Tim Yamin 20 years ago
parent d2b19c4771
commit 11ca208e3f

@ -65,6 +65,7 @@ longusage() {
echo " --do-keymap-auto Forces keymap selection at boot" echo " --do-keymap-auto Forces keymap selection at boot"
echo " --no-lvm2 Don't include LVM2 support" echo " --no-lvm2 Don't include LVM2 support"
echo " --bootloader=grub Add new kernel to GRUB configuration" echo " --bootloader=grub Add new kernel to GRUB configuration"
echo " --linuxrc=<file> Specifies a user created linuxrc"
echo " Internals" echo " Internals"
echo " --arch-override=<arch> Force to arch instead of autodetect" echo " --arch-override=<arch> Force to arch instead of autodetect"
echo " --cachedir=<dir> Override the default cache location" echo " --cachedir=<dir> Override the default cache location"
@ -100,39 +101,39 @@ parse_opt() {
parse_cmdline() { parse_cmdline() {
case "$*" in case "$*" in
--kernel-cc*) --kernel-cc=*)
CMD_KERNEL_CC=`parse_opt "$*"` CMD_KERNEL_CC=`parse_opt "$*"`
print_info 2 "CMD_KERNEL_CC: $CMD_KERNEL_CC" print_info 2 "CMD_KERNEL_CC: $CMD_KERNEL_CC"
;; ;;
--kernel-ld*) --kernel-ld=*)
CMD_KERNEL_LD=`parse_opt "$*"` CMD_KERNEL_LD=`parse_opt "$*"`
print_info 2 "CMD_KERNEL_LD: $CMD_KERNEL_LD" print_info 2 "CMD_KERNEL_LD: $CMD_KERNEL_LD"
;; ;;
--kernel-as*) --kernel-as=*)
CMD_KERNEL_AS=`parse_opt "$*"` CMD_KERNEL_AS=`parse_opt "$*"`
print_info 2 "CMD_KERNEL_AS: $CMD_KERNEL_AS" print_info 2 "CMD_KERNEL_AS: $CMD_KERNEL_AS"
;; ;;
--kernel-make*) --kernel-make=*)
CMD_KERNEL_MAKE=`parse_opt "$*"` CMD_KERNEL_MAKE=`parse_opt "$*"`
print_info 2 "CMD_KERNEL_MAKE: $CMD_KERNEL_MAKE" print_info 2 "CMD_KERNEL_MAKE: $CMD_KERNEL_MAKE"
;; ;;
--utils-cc*) --utils-cc=*)
CMD_UTILS_CC=`parse_opt "$*"` CMD_UTILS_CC=`parse_opt "$*"`
print_info 2 "CMD_UTILS_CC: $CMD_UTILS_CC" print_info 2 "CMD_UTILS_CC: $CMD_UTILS_CC"
;; ;;
--utils-ld*) --utils-ld=*)
CMD_UTILS_LD=`parse_opt "$*"` CMD_UTILS_LD=`parse_opt "$*"`
print_info 2 "CMD_UTILS_LD: $CMD_UTILS_LD" print_info 2 "CMD_UTILS_LD: $CMD_UTILS_LD"
;; ;;
--utils-as*) --utils-as=*)
CMD_UTILS_AS=`parse_opt "$*"` CMD_UTILS_AS=`parse_opt "$*"`
print_info 2 "CMD_UTILS_AS: $CMD_UTILS_AS" print_info 2 "CMD_UTILS_AS: $CMD_UTILS_AS"
;; ;;
--utils-make*) --utils-make=*)
CMD_UTILS_MAKE=`parse_opt "$*"` CMD_UTILS_MAKE=`parse_opt "$*"`
print_info 2 "CMD_UTILS_MAKE: $CMD_UTILS_MAKE" print_info 2 "CMD_UTILS_MAKE: $CMD_UTILS_MAKE"
;; ;;
--makeopts*) --makeopts=*)
CMD_MAKEOPTS=`parse_opt "$*"` CMD_MAKEOPTS=`parse_opt "$*"`
print_info 2 "CMD_MAKEOPTS: $CMD_MAKEOPTS" print_info 2 "CMD_MAKEOPTS: $CMD_MAKEOPTS"
;; ;;
@ -156,11 +157,11 @@ parse_cmdline() {
CMD_NOLVM2=1 CMD_NOLVM2=1
print_info 2 'CMD_NOLVM2: 1' print_info 2 'CMD_NOLVM2: 1'
;; ;;
--bootloader*) --bootloader=*)
CMD_BOOTLOADER=`parse_opt "$*"` CMD_BOOTLOADER=`parse_opt "$*"`
print_info 2 "CMD_BOOTLOADER: $CMD_BOOTLOADER" print_info 2 "CMD_BOOTLOADER: $CMD_BOOTLOADER"
;; ;;
--debuglevel*) --debuglevel=*)
CMD_DEBUGLEVEL=`parse_opt "$*"` CMD_DEBUGLEVEL=`parse_opt "$*"`
DEBUGLEVEL="${CMD_DEBUGLEVEL}" DEBUGLEVEL="${CMD_DEBUGLEVEL}"
print_info 2 "CMD_DEBUGLEVEL: $CMD_DEBUGLEVEL" print_info 2 "CMD_DEBUGLEVEL: $CMD_DEBUGLEVEL"
@ -277,19 +278,19 @@ parse_cmdline() {
CMD_UDEV=0 CMD_UDEV=0
print_info 2 "CMD_UDEV: $CMD_UDEV" print_info 2 "CMD_UDEV: $CMD_UDEV"
;; ;;
--callback*) --callback=*)
CMD_CALLBACK=`parse_opt "$*"` CMD_CALLBACK=`parse_opt "$*"`
print_info 2 "CMD_CALLBACK: $CMD_CALLBACK/$*" print_info 2 "CMD_CALLBACK: $CMD_CALLBACK/$*"
;; ;;
--postconf*) --postconf=*)
CMD_POSTCONF=`parse_opt "$*"` CMD_POSTCONF=`parse_opt "$*"`
print_info 2 "CMD_POSTCONF: $CMD_POSTCONF/$*" print_info 2 "CMD_POSTCONF: $CMD_POSTCONF/$*"
;; ;;
--tempdir*) --tempdir=*)
TEMP=`parse_opt "$*"` TEMP=`parse_opt "$*"`
print_info 2 "TEMP: $TEMP" print_info 2 "TEMP: $TEMP"
;; ;;
--arch-override*) --arch-override=*)
CMD_ARCHOVERRIDE=`parse_opt "$*"` CMD_ARCHOVERRIDE=`parse_opt "$*"`
print_info 2 "CMD_ARCHOVERRIDE: $CMD_ARCHOVERRIDE" print_info 2 "CMD_ARCHOVERRIDE: $CMD_ARCHOVERRIDE"
;; ;;
@ -301,32 +302,36 @@ parse_cmdline() {
CMD_USECOLOR=0 CMD_USECOLOR=0
print_info 2 "CMD_USECOLOR: $CMD_USECOLOR" print_info 2 "CMD_USECOLOR: $CMD_USECOLOR"
;; ;;
--debugfile*) --debugfile=*)
CMD_DEBUGFILE=`parse_opt "$*"` CMD_DEBUGFILE=`parse_opt "$*"`
DEBUGFILE=`parse_opt "$*"` DEBUGFILE=`parse_opt "$*"`
print_info 2 "CMD_DEBUGFILE: $CMD_DEBUGFILE" print_info 2 "CMD_DEBUGFILE: $CMD_DEBUGFILE"
print_info 2 "DEBUGFILE: $CMD_DEBUGFILE" print_info 2 "DEBUGFILE: $CMD_DEBUGFILE"
;; ;;
--kerneldir*) --kerneldir=*)
CMD_KERNELDIR=`parse_opt "$*"` CMD_KERNELDIR=`parse_opt "$*"`
print_info 2 "CMD_KERNELDIR: $CMD_KERNELDIR" print_info 2 "CMD_KERNELDIR: $CMD_KERNELDIR"
;; ;;
--kernel-config*) --kernel-config=*)
CMD_KERNEL_CONFIG=`parse_opt "$*"` CMD_KERNEL_CONFIG=`parse_opt "$*"`
print_info 2 "CMD_KERNEL_CONFIG: $CMD_KERNEL_CONFIG" print_info 2 "CMD_KERNEL_CONFIG: $CMD_KERNEL_CONFIG"
;; ;;
--module-prefix*) --module-prefix=*)
CMD_INSTALL_MOD_PATH=`parse_opt "$*"` CMD_INSTALL_MOD_PATH=`parse_opt "$*"`
print_info 2 "CMD_INSTALL_MOD_PATH: $CMD_INSTALL_MOD_PATH" print_info 2 "CMD_INSTALL_MOD_PATH: $CMD_INSTALL_MOD_PATH"
;; ;;
--cachedir*) --cachedir=*)
CACHE_DIR=`parse_opt "$*"` CACHE_DIR=`parse_opt "$*"`
print_info 2 "CACHE_DIR: $CACHE_DIR" print_info 2 "CACHE_DIR: $CACHE_DIR"
;; ;;
--minkernpackage*) --minkernpackage=*)
CMD_MINKERNPACKAGE=`parse_opt "$*"` CMD_MINKERNPACKAGE=`parse_opt "$*"`
print_info 2 "MINKERNPACKAGE: $CMD_MINKERNPACKAGE" print_info 2 "MINKERNPACKAGE: $CMD_MINKERNPACKAGE"
;; ;;
--linuxrc=*)
CMD_LINUXRC=`parse_opt "$*"`
print_info 2 "CMD_LINUXRC: $CMD_LINUXRC"
;;
all) all)
BUILD_KERNEL=1 BUILD_KERNEL=1
BUILD_INITRD=1 BUILD_INITRD=1

@ -184,12 +184,18 @@ create_initrd_modules() {
} }
create_initrd_aux() { create_initrd_aux() {
if [ -f "${CMD_LINUXRC}" ]
then
cp "${CMD_LINUXRC}" "${TEMP}/initrd-temp/linuxrc"
print_info 2 " >> Copying user specified linuxrc: ${CMD_LINUXRC}"
else
if [ -f "${GK_SHARE}/${ARCH}/linuxrc" ] if [ -f "${GK_SHARE}/${ARCH}/linuxrc" ]
then then
cp "${GK_SHARE}/${ARCH}/linuxrc" "${TEMP}/initrd-temp/linuxrc" cp "${GK_SHARE}/${ARCH}/linuxrc" "${TEMP}/initrd-temp/linuxrc"
else else
cp "${GK_SHARE}/generic/linuxrc" "${TEMP}/initrd-temp/linuxrc" cp "${GK_SHARE}/generic/linuxrc" "${TEMP}/initrd-temp/linuxrc"
fi fi
fi
if [ -f "${GK_SHARE}/${ARCH}/initrd.scripts" ] if [ -f "${GK_SHARE}/${ARCH}/initrd.scripts" ]
then then

Loading…
Cancel
Save