116 |
then |
then |
117 |
liloConfig="" |
liloConfig="" |
118 |
bootPrefix=/boot |
bootPrefix=/boot |
119 |
|
extlinuxConfig=$(readlink -f /etc/extlinux.conf 2>/dev/null) |
120 |
ubootDir=${UBOOT_DIR:-"/boot"} |
ubootDir=${UBOOT_DIR:-"/boot"} |
121 |
ubootScript=$ubootDir/${UBOOT_SCR:-"boot.scr"} |
ubootScript=$ubootDir/${UBOOT_SCR:-"boot.scr"} |
122 |
ubootKList=${UBOOT_KLIST:-"klist.txt"} |
ubootKList=${UBOOT_KLIST:-"klist.txt"} |
145 |
dracut="" |
dracut="" |
146 |
dracuthostonly="" |
dracuthostonly="" |
147 |
initrdfile="" |
initrdfile="" |
148 |
|
devtreefile="" |
149 |
moddep="" |
moddep="" |
150 |
verbose="" |
verbose="" |
151 |
makedefault="" |
makedefault="" |
163 |
echo " [--banner=<banner>] [--multiboot=multiboot]" >&2 |
echo " [--banner=<banner>] [--multiboot=multiboot]" >&2 |
164 |
echo " [--mbargs=mbargs] [--make-default] [--add-dracut-args]" >&2 |
echo " [--mbargs=mbargs] [--make-default] [--add-dracut-args]" >&2 |
165 |
echo " [--add-plymouth-initrd]" >&2 |
echo " [--add-plymouth-initrd]" >&2 |
166 |
echo " [--host-only]" >&2 |
echo " [--host-only] [--devtree=<devicetree.dtb>]" >&2 |
167 |
echo " <--install | --remove | --update> <kernel-version>" >&2 |
echo " <--install | --remove | --update> <kernel-version>" >&2 |
168 |
echo " (ex: $(basename $0) --mkinitrd --depmod --install 2.4.7-2)" >&2 |
echo " (ex: $(basename $0) --mkinitrd --depmod --install 2.4.7-2)" >&2 |
169 |
exit 1 |
exit 1 |
172 |
install() |
install() |
173 |
{ |
{ |
174 |
# XXX kernel should be able to be specified also (or work right on ia64) |
# XXX kernel should be able to be specified also (or work right on ia64) |
175 |
if [ ! -f ${bootPrefix}/${kernelName}-${version} ] |
if [ ! -f ${kernelImage} ] |
176 |
then |
then |
177 |
[[ -n ${verbose} ]] && echo "kernel for ${version} does not exist, not running grubby" |
[[ -n ${verbose} ]] && echo "kernel for ${version} does not exist, not running grubby" |
178 |
return |
return |
190 |
fi |
fi |
191 |
fi |
fi |
192 |
|
|
193 |
|
DEVTREE="" |
194 |
|
if [[ x${devtreefile} != x ]] && [ -f ${devtreefile} ] |
195 |
|
then |
196 |
|
[[ -n ${verbose} ]] && echo "found ${devtreefile} and using it with grubby" |
197 |
|
DEVTREE="--devtree ${devtreefile}" |
198 |
|
fi |
199 |
|
|
200 |
# FIXME: is this a good heuristic to find out if we're on iSeries? |
# FIXME: is this a good heuristic to find out if we're on iSeries? |
201 |
if [ -d /proc/iSeries ] |
if [ -d /proc/iSeries ] |
202 |
then |
then |
204 |
if [[ -z ${initrdfile} ]] |
if [[ -z ${initrdfile} ]] |
205 |
then |
then |
206 |
[[ -n ${verbose} ]] && echo "No initrd, just adding system map" |
[[ -n ${verbose} ]] && echo "No initrd, just adding system map" |
207 |
/sbin/addSystemMap ${bootPrefix}/System.map-${version} ${bootPrefix}/${kernelName}-${version} ${bootPrefix}/vmlinitrd-${version} |
/sbin/addSystemMap ${bootPrefix}/System.map-${version} ${kernelImage} ${bootPrefix}/vmlinitrd-${version} |
208 |
else |
else |
209 |
/sbin/addSystemMap ${bootPrefix}/System.map-${version} ${bootPrefix}/${kernelName}-${version} ${bootPrefix}/vmlinux.sm-${version} |
/sbin/addSystemMap ${bootPrefix}/System.map-${version} ${kernelImage} ${bootPrefix}/vmlinux.sm-${version} |
210 |
/sbin/addRamDisk ${initrdfile} ${bootPrefix}/System.map-${version} ${bootPrefix}/vmlinux.sm-${version} ${bootPrefix}/vmlinitrd-${version} 2>/dev/null |
/sbin/addRamDisk ${initrdfile} ${bootPrefix}/System.map-${version} ${bootPrefix}/vmlinux.sm-${version} ${bootPrefix}/vmlinitrd-${version} 2>/dev/null |
211 |
rm ${bootPrefix}/vmlinux.sm-${version} |
rm ${bootPrefix}/vmlinux.sm-${version} |
212 |
fi |
fi |
214 |
fi |
fi |
215 |
|
|
216 |
# get the root filesystem to use |
# get the root filesystem to use |
217 |
rootdevice=$(awk '{ if ($1 !~ /^[ \t]*#/ && $2 == "/") { print $1; }}' /etc/fstab) |
rootdevice=$(awk '{ if ($1 !~ /^[ \t]*#/ && $2 == "/") { print $1; }}' /etc/fstab 2>/dev/null) |
218 |
|
if [[ -z $rootdevice ]] |
219 |
|
then |
220 |
|
rootdevice=$(grep -o -P "(?<=root=)\S+" /proc/cmdline) |
221 |
|
fi |
222 |
|
|
223 |
if [[ -n ${mbkernel} ]] && [[ -n ${cfgLilo} ]] && [[ ${liloFlag} != elilo ]] |
if [[ -n ${mbkernel} ]] && [[ -n ${cfgLilo} ]] && [[ ${liloFlag} != elilo ]] |
224 |
then |
then |
226 |
cfgLilo="" |
cfgLilo="" |
227 |
fi |
fi |
228 |
|
|
229 |
if [[ -n ${cfgGrub} ]] |
if [[ -n ${banner} ]] |
230 |
then |
then |
231 |
[[ -n ${verbose} ]] && echo "adding ${version} to ${grubConfig}" |
if [[ ${ARCH} = s390 ]] || [[ ${ARCH} = s390x ]] |
|
|
|
|
if [[ -n ${banner} ]] |
|
|
then |
|
|
title="${banner} [ ${version} ]" |
|
|
elif [ -f /etc/mageversion ] |
|
232 |
then |
then |
233 |
title="Magellan Linux $(< /etc/mageversion) [ ${version} ]" |
title=$(echo ${banner} | sed 's/ /_/g') |
|
elif [[ $(read_os_release id) = magellan ]] |
|
|
then |
|
|
title="$(read_os_release name) $(read_os_release version_id) [ ${version} ]" |
|
234 |
else |
else |
235 |
title="Magellan Linux [ ${version} ]" |
title="${banner} [ ${version} ]" |
236 |
fi |
fi |
237 |
|
elif [[ ${ARCH} = s390 ]] || [[ ${ARCH} = s390x ]] |
238 |
|
then |
239 |
|
title=$(echo ${version} | sed 's/ /_/g') |
240 |
|
elif [ -f /etc/os-release ] |
241 |
|
then |
242 |
|
title="$(read_os_release name) $(read_os_release version_id) [ ${version} ]" |
243 |
|
elif [ -f /etc/mageversion ] |
244 |
|
then |
245 |
|
title="Magellan Linux $(< /etc/mageversion) [ ${version} ]" |
246 |
|
else |
247 |
|
title="Magellan Linux [ ${version} ]" |
248 |
|
fi |
249 |
|
|
250 |
|
if [[ -n ${cfgGrub} ]] |
251 |
|
then |
252 |
|
[[ -n ${verbose} ]] && echo "adding ${version} to ${grubConfig}" |
253 |
|
|
254 |
${grubby} --grub -c ${grubConfig} \ |
${grubby} --grub -c ${grubConfig} \ |
255 |
--add-kernel=${bootPrefix}/${kernelName}-${version} \ |
--add-kernel=${kernelImage} \ |
256 |
${INITRD} --copy-default ${makedefault} --title "${title}" \ |
${INITRD} --copy-default ${makedefault} --title "${title}" \ |
257 |
${mbkernel:+--add-multiboot="${mbkernel}"} ${mbargs:+--mbargs="${mbargs}"} \ |
${mbkernel:+--add-multiboot="${mbkernel}"} ${mbargs:+--mbargs="${mbargs}"} \ |
258 |
--args="root=${rootdevice} ${kernargs}" --remove-kernel="TITLE=${title}" |
--args="root=${rootdevice} ${kernargs}" --remove-kernel="TITLE=${title}" |
263 |
then |
then |
264 |
[[ -n ${verbose} ]] && echo "adding ${version} to ${grub2Config}" |
[[ -n ${verbose} ]] && echo "adding ${version} to ${grub2Config}" |
265 |
|
|
|
if [[ -n ${banner} ]] |
|
|
then |
|
|
title="${banner} [ ${version} ]" |
|
|
elif [ -f /etc/mageversion ] |
|
|
then |
|
|
title="Magellan Linux $(< /etc/mageversion) [ ${version} ]" |
|
|
elif [[ $(read_os_release id) = magellan ]] |
|
|
then |
|
|
title="$(read_os_release name) $(read_os_release version_id) [ ${version} ]" |
|
|
else |
|
|
title="Magellan Linux [ ${version} ]" |
|
|
fi |
|
266 |
${grubby} --grub2 -c ${grub2Config} \ |
${grubby} --grub2 -c ${grub2Config} \ |
267 |
--add-kernel=${bootPrefix}/${kernelName}-${version} \ |
--add-kernel=${kernelImage} \ |
268 |
${INITRD} --copy-default ${makedefault} --title "${title}" \ |
${INITRD} --copy-default ${makedefault} --title "${title}" \ |
269 |
${mbkernel:+--add-multiboot="${mbkernel}"} \ |
${mbkernel:+--add-multiboot="${mbkernel}"} \ |
270 |
${mbargs:+--mbargs="${mbargs}"} \ |
${mbargs:+--mbargs="${mbargs}"} \ |
276 |
then |
then |
277 |
[[ -n ${verbose} ]] && echo "adding ${version} to ${grub2EfiConfig}" |
[[ -n ${verbose} ]] && echo "adding ${version} to ${grub2EfiConfig}" |
278 |
|
|
|
if [[ -n ${banner} ]] |
|
|
then |
|
|
title="${banner} [ ${version} ]" |
|
|
elif [ -f /etc/mageversion ] |
|
|
then |
|
|
title="Magellan Linux $(< /etc/mageversion) [ ${version} ]" |
|
|
elif [[ $(read_os_release id) = magellan ]] |
|
|
then |
|
|
title="$(read_os_release name) $(read_os_release version_id) [ ${version} ]" |
|
|
else |
|
|
title="Magellan Linux [ ${version} ]" |
|
|
fi |
|
279 |
${grubby} --grub2 -c ${grub2EfiConfig} --efi \ |
${grubby} --grub2 -c ${grub2EfiConfig} --efi \ |
280 |
--add-kernel=${bootPrefix}/${kernelName}-${version} \ |
--add-kernel=${kernelImage} ${DEVTREE} \ |
281 |
${INITRD} --copy-default ${makedefault} --title "${title}" \ |
${INITRD} --copy-default ${makedefault} --title "${title}" \ |
282 |
${mbkernel:+--add-multiboot="${mbkernel}"} \ |
${mbkernel:+--add-multiboot="${mbkernel}"} \ |
283 |
${mbargs:+--mbargs="${mbargs}"} \ |
${mbargs:+--mbargs="${mbargs}"} \ |
290 |
then |
then |
291 |
[[ -n ${verbose} ]] && echo "adding ${version} to ${liloConfig}" |
[[ -n ${verbose} ]] && echo "adding ${version} to ${liloConfig}" |
292 |
|
|
293 |
${grubby} --add-kernel=${bootPrefix}/${kernelName}-${version} ${INITRD} \ |
${grubby} --add-kernel=${kernelImage} ${INITRD} \ |
294 |
--copy-default ${makedefault} --title ${version} \ |
--copy-default ${makedefault} --title "${title}" \ |
295 |
${mbkernel:+--add-multiboot="${mbkernel}"} ${mbargs:+--mbargs="${mbargs}"} \ |
${mbkernel:+--add-multiboot="${mbkernel}"} ${mbargs:+--mbargs="${mbargs}"} \ |
296 |
--args="root=${rootdevice} ${kernargs}" --remove-kernel="TITLE=${version}" \ |
--args="root=${rootdevice} ${kernargs}" --remove-kernel="TITLE=${version}" \ |
297 |
--${liloFlag} |
--${liloFlag} |
314 |
then |
then |
315 |
[[ -n ${verbose} ]] && echo "adding ${version} to ${extlinuxConfig}" |
[[ -n ${verbose} ]] && echo "adding ${version} to ${extlinuxConfig}" |
316 |
|
|
|
if [[ -n ${banner} ]] |
|
|
then |
|
|
title="${banner} [ ${version} ]" |
|
|
elif [ -f /etc/mageversion ] |
|
|
then |
|
|
title="Magellan Linux $(< /etc/mageversion) [ ${version} ]" |
|
|
elif [[ $(read_os_release id) = magellan ]] |
|
|
then |
|
|
title="$(read_os_release name) $(read_os_release version_id) [ ${version} ]" |
|
|
else |
|
|
title="Magellan Linux [ ${version} ]" |
|
|
fi |
|
317 |
${grubby} --extlinux -c ${extlinuxConfig} \ |
${grubby} --extlinux -c ${extlinuxConfig} \ |
318 |
--add-kernel=${bootPrefix}/${kernelName}-${version} \ |
--add-kernel=${kernelImage} \ |
319 |
${INITRD} --copy-default ${makedefault} --title "${title}" \ |
${INITRD} --copy-default ${makedefault} --title "${title}" \ |
320 |
${mbkernel:+--add-multiboot="${mbkernel}"} ${mbargs:+--mbargs="${mbargs}"} \ |
${mbkernel:+--add-multiboot="${mbkernel}"} ${mbargs:+--mbargs="${mbargs}"} \ |
321 |
--args="root=${rootdevice} ${kernargs}" --remove-kernel="TITLE=${title}" |
--args="root=${rootdevice} ${kernargs}" --remove-kernel="TITLE=${title}" |
330 |
if [ -d /proc/iSeries ] |
if [ -d /proc/iSeries ] |
331 |
then |
then |
332 |
[[ -n ${verbose} ]] && echo "On an iSeries, remove img file" |
[[ -n ${verbose} ]] && echo "On an iSeries, remove img file" |
333 |
rm -f ${bootPrefix}/${kernelName}-${version}.img 2>/dev/null |
rm -f ${kernelImage}.img 2>/dev/null |
334 |
return |
return |
335 |
fi |
fi |
336 |
|
|
338 |
then |
then |
339 |
[[ -n ${verbose} ]] && echo "removing ${version} from ${grubConfig}" |
[[ -n ${verbose} ]] && echo "removing ${version} from ${grubConfig}" |
340 |
${grubby} --grub -c ${grubConfig} \ |
${grubby} --grub -c ${grubConfig} \ |
341 |
--remove-kernel=${bootPrefix}/${kernelName}-${version} |
--remove-kernel=${kernelImage} |
342 |
else |
else |
343 |
[[ -n ${verbose} ]] && echo "${grubConfig} does not exist, not running grubby for grub 0.97" |
[[ -n ${verbose} ]] && echo "${grubConfig} does not exist, not running grubby for grub 0.97" |
344 |
fi |
fi |
346 |
then |
then |
347 |
[[ -n ${verbose} ]] && echo "removing ${version} from ${grub2Config}" |
[[ -n ${verbose} ]] && echo "removing ${version} from ${grub2Config}" |
348 |
${grubby} --grub2 -c ${grub2Config} \ |
${grubby} --grub2 -c ${grub2Config} \ |
349 |
--remove-kernel=${bootPrefix}/${kernelName}-${version} |
--remove-kernel=${kernelImage} |
350 |
else |
else |
351 |
[[ -n ${verbose} ]] && echo "${grub2Config} does not exist, not running grubby for grub 2" |
[[ -n ${verbose} ]] && echo "${grub2Config} does not exist, not running grubby for grub 2" |
352 |
fi |
fi |
353 |
if [[ -n ${cfgGrub2Efi} ]] |
if [[ -n ${cfgGrub2Efi} ]] |
354 |
then |
then |
355 |
[[ -n ${verbose} ]] && echo "removing ${version} from ${grub2EfiConfig}" |
[[ -n ${verbose} ]] && echo "removing ${version} from ${grub2EfiConfig}" |
356 |
${grubby} --grub2 -c ${grub2EfiConfig} \ |
${grubby} --grub2 -c ${grub2EfiConfig} --efi \ |
357 |
--remove-kernel=${bootPrefix}/${kernelName}-${version} |
--remove-kernel=${kernelImage} |
358 |
else |
else |
359 |
[[ -n ${verbose} ]] && echo "${grub2EfiConfig} does not exist, not running grubby grub 2 with UEFI" |
[[ -n ${verbose} ]] && echo "${grub2EfiConfig} does not exist, not running grubby grub 2 with UEFI" |
360 |
fi |
fi |
362 |
if [[ -n ${cfgLilo} ]] |
if [[ -n ${cfgLilo} ]] |
363 |
then |
then |
364 |
[[ -n ${verbose} ]] && echo "removing ${version} from ${liloConfig}" |
[[ -n ${verbose} ]] && echo "removing ${version} from ${liloConfig}" |
365 |
${grubby} --remove-kernel=${bootPrefix}/${kernelName}-${version} --${liloFlag} |
${grubby} --remove-kernel=${kernelImage} --${liloFlag} |
366 |
|
|
367 |
if [[ -n ${runLilo} ]] |
if [[ -n ${runLilo} ]] |
368 |
then |
then |
421 |
fi |
fi |
422 |
|
|
423 |
mv ${tmpKList} ${ubootDir}/${ubootKList} |
mv ${tmpKList} ${ubootDir}/${ubootKList} |
424 |
|
[ -x /sbin/a-b-c ] && /sbin/a-b-c |
425 |
else |
else |
426 |
[[ -n ${verbose} ]] && echo "uImage ${newversion} does not exist!" |
[[ -n ${verbose} ]] && echo "uImage ${newversion} does not exist!" |
427 |
[ -f ${tmpKList} ] && rm -f ${tmpKList} |
[ -f ${tmpKList} ] && rm -f ${tmpKList} |
437 |
then |
then |
438 |
[[ -n ${verbose} ]] && echo "removing ${version} from ${extlinuxConfig}" |
[[ -n ${verbose} ]] && echo "removing ${version} from ${extlinuxConfig}" |
439 |
${grubby} --extlinux -c ${extlinuxConfig} \ |
${grubby} --extlinux -c ${extlinuxConfig} \ |
440 |
--remove-kernel=${bootPrefix}/${kernelName}-${version} |
--remove-kernel=${kernelImage} |
441 |
else |
else |
442 |
[[ -n ${verbose} ]] && echo "${extlinuxConfig} does not exist, not running grubby for extlinux" |
[[ -n ${verbose} ]] && echo "${extlinuxConfig} does not exist, not running grubby for extlinux" |
443 |
fi |
fi |
445 |
|
|
446 |
update() |
update() |
447 |
{ |
{ |
448 |
if [ ! -f ${bootPrefix}/${kernelName}-${version} ] |
if [ ! -f ${kernelImage} ] |
449 |
then |
then |
450 |
[[ -n ${verbose} ]] && echo "kernel for ${version} does not exist, not running grubby" |
[[ -n ${verbose} ]] && echo "kernel for ${version} does not exist, not running grubby" |
451 |
return |
return |
467 |
then |
then |
468 |
[[ -n ${verbose} ]] && echo "updating ${version} from ${grubConfig}" |
[[ -n ${verbose} ]] && echo "updating ${version} from ${grubConfig}" |
469 |
${grubby} --grub -c ${grubConfig} \ |
${grubby} --grub -c ${grubConfig} \ |
470 |
--update-kernel=${bootPrefix}/${kernelName}-${version} \ |
--update-kernel=${kernelImage} \ |
471 |
${INITRD} \ |
${INITRD} \ |
472 |
${kernargs:+--args="${kernargs}"} \ |
${kernargs:+--args="${kernargs}"} \ |
473 |
${removeargs:+--remove-args="${removeargs}"} |
${removeargs:+--remove-args="${removeargs}"} \ |
474 |
|
${mbkernel:+--add-multiboot="${mbkernel}"} |
475 |
else |
else |
476 |
[[ -n ${verbose} ]] && echo "${grubConfig} does not exist, not running grubby" |
[[ -n ${verbose} ]] && echo "${grubConfig} does not exist, not running grubby" |
477 |
fi |
fi |
480 |
then |
then |
481 |
[[ -n ${verbose} ]] && echo "updating ${version} from ${grub2Config}" |
[[ -n ${verbose} ]] && echo "updating ${version} from ${grub2Config}" |
482 |
${grubby} --grub2 -c ${grub2Config} \ |
${grubby} --grub2 -c ${grub2Config} \ |
483 |
--update-kernel=${bootPrefix}/${kernelName}-${version} \ |
--update-kernel=${kernelImage} \ |
484 |
${INITRD} \ |
${INITRD} \ |
485 |
${kernargs:+--args="${kernargs}"} \ |
${kernargs:+--args="${kernargs}"} \ |
486 |
${removeargs:+--remove-args="${removeargs}"} |
${removeargs:+--remove-args="${removeargs}"} |
491 |
if [[ -n ${cfgGrub2Efi} ]] |
if [[ -n ${cfgGrub2Efi} ]] |
492 |
then |
then |
493 |
[[ -n ${verbose} ]] && echo "updating ${version} from ${grub2EfiConfig}" |
[[ -n ${verbose} ]] && echo "updating ${version} from ${grub2EfiConfig}" |
494 |
${grubby} --grub2 -c ${grub2EfiConfig} \ |
${grubby} --grub2 -c ${grub2EfiConfig} --efi \ |
495 |
--update-kernel=${bootPrefix}/${kernelName}-${version} \ |
--update-kernel=${kernelImage} \ |
496 |
${INITRD} \ |
${INITRD} \ |
497 |
${kernargs:+--args="${kernargs}"} \ |
${kernargs:+--args="${kernargs}"} \ |
498 |
${removeargs:+--remove-args="${removeargs}"} |
${removeargs:+--remove-args="${removeargs}"} |
503 |
if [[ -n ${cfgLilo} ]] |
if [[ -n ${cfgLilo} ]] |
504 |
then |
then |
505 |
[[ -n ${verbose} ]] && echo "updating ${version} from ${liloConfig}" |
[[ -n ${verbose} ]] && echo "updating ${version} from ${liloConfig}" |
506 |
${grubby} --update-kernel=${bootPrefix}/${kernelName}-${version} \ |
${grubby} --update-kernel=${kernelImage} \ |
507 |
${INITRD} \ |
${INITRD} \ |
508 |
${kernargs:+--args="${kernargs}"} \ |
${kernargs:+--args="${kernargs}"} \ |
509 |
${removeargs:+--remove-args="${removeargs}"} \ |
${removeargs:+--remove-args="${removeargs}"} \ |
530 |
[[ -n ${verbose} ]] && echo "creating uImage-${version}" |
[[ -n ${verbose} ]] && echo "creating uImage-${version}" |
531 |
mkimage -A arm -O linux -T kernel -C none -a ${ubootAddress} \ |
mkimage -A arm -O linux -T kernel -C none -a ${ubootAddress} \ |
532 |
-e ${ubootAddress} -n ${version} \ |
-e ${ubootAddress} -n ${version} \ |
533 |
-d ${bootPrefix}/${kernelName}-${version} ${ubootDir}/uImage-${version} |
-d ${kernelImage} ${ubootDir}/uImage-${version} |
534 |
|
|
535 |
[[ -n ${verbose} ]] && echo "creating uInitrd-${version}" |
[[ -n ${verbose} ]] && echo "creating uInitrd-${version}" |
536 |
mkimage -A arm -O linux -T ramdisk -C none -a 0 -e 0 \ |
mkimage -A arm -O linux -T ramdisk -C none -a 0 -e 0 \ |
549 |
[[ -n ${verbose} ]] && echo "copy uInitrd-${version} error, kernel not installed!" && exit |
[[ -n ${verbose} ]] && echo "copy uInitrd-${version} error, kernel not installed!" && exit |
550 |
fi |
fi |
551 |
echo ${version} >> ${ubootDir}/${ubootKList} |
echo ${version} >> ${ubootDir}/${ubootKList} |
552 |
|
[ -x /sbin/a-b-c ] && /sbin/a-b-c |
553 |
else |
else |
554 |
[[ -n ${verbose} ]] && echo "cannot make ${version} the default" |
[[ -n ${verbose} ]] && echo "cannot make ${version} the default" |
555 |
fi |
fi |
561 |
then |
then |
562 |
[[ -n ${verbose} ]] && echo "updating ${version} from ${extlinuxConfig}" |
[[ -n ${verbose} ]] && echo "updating ${version} from ${extlinuxConfig}" |
563 |
${grubby} --extlinux -c ${extlinuxConfig} \ |
${grubby} --extlinux -c ${extlinuxConfig} \ |
564 |
--update-kernel=${bootPrefix}/${kernelName}-${version} \ |
--update-kernel=${kernelImage} \ |
565 |
${INITRD} \ |
${INITRD} \ |
566 |
${kernargs:+--args="${kernargs}"} \ |
${kernargs:+--args="${kernargs}"} \ |
567 |
${removeargs:+--remove-args="${removeargs}"} |
${removeargs:+--remove-args="${removeargs}"} |
603 |
doRmmoddep() |
doRmmoddep() |
604 |
{ |
{ |
605 |
[[ -n ${verbose} ]] && echo "removing modules.dep info for ${version}" |
[[ -n ${verbose} ]] && echo "removing modules.dep info for ${version}" |
606 |
[ -d /lib/modules/${version} ] && rm -f /lib/modules/${version}/modules.* |
if [ -d /lib/modules/${version} ] |
607 |
|
then |
608 |
|
rm -f /lib/modules/${version}/modules.*.bin \ |
609 |
|
/lib/modules/${version}/modules.{alias,dep,devname,symbols,softdep} |
610 |
|
fi |
611 |
} |
} |
612 |
|
|
613 |
|
|
622 |
initrd="remove" |
initrd="remove" |
623 |
;; |
;; |
624 |
|
|
625 |
|
--devtree*) |
626 |
|
if [[ $1 == --devtree\=* ]] |
627 |
|
then |
628 |
|
devtreefile="${1#--devtreefile=}" |
629 |
|
else |
630 |
|
devtreefile="$2" |
631 |
|
shift |
632 |
|
fi |
633 |
|
;; |
634 |
|
|
635 |
--dracut) |
--dracut) |
636 |
dracut=--dracut |
dracut=--dracut |
637 |
;; |
;; |
641 |
;; |
;; |
642 |
|
|
643 |
--initrdfile*) |
--initrdfile*) |
644 |
if echo $1 | grep '=' >/dev/null |
if [[ $1 == --initrdfile\=* ]] |
645 |
then |
then |
646 |
initrdfile=$(echo $1 | sed 's/^--initrdfile=//') |
initrdfile=${1#--initrdfile=} |
647 |
else |
else |
648 |
initrdfile=$2 |
initrdfile=$2 |
649 |
shift |
shift |
651 |
;; |
;; |
652 |
|
|
653 |
--kernel-args*) |
--kernel-args*) |
654 |
if echo $1 | grep '=' >/dev/null |
if [[ $1 == --kernel-args\=* ]] |
655 |
then |
then |
656 |
kernargs=$(echo $1 | sed 's/^--kernel-args=//') |
kernargs=${1#--kernel-args=} |
657 |
else |
else |
658 |
kernargs=$2 |
kernargs=$2 |
659 |
shift |
shift |
661 |
;; |
;; |
662 |
|
|
663 |
--remove-args*) |
--remove-args*) |
664 |
if echo $1 | grep '=' >/dev/null |
if [[ $1 == --remove-args\=* ]] |
665 |
then |
then |
666 |
removeargs=$(echo $1 | sed 's/^--remove-args=//') |
removeargs=${1#--remove-args=} |
667 |
else |
else |
668 |
removeargs=$2 |
removeargs=$2 |
669 |
shift |
shift |
671 |
;; |
;; |
672 |
|
|
673 |
--banner*) |
--banner*) |
674 |
if echo $1 | grep '=' >/dev/null |
if [[ $1 == --banner\=* ]] |
675 |
then |
then |
676 |
banner=$(echo $1 | sed 's/^--banner=//') |
banner=${1#--banner=} |
677 |
else |
else |
678 |
banner=$2 |
banner=$2 |
679 |
shift |
shift |
681 |
;; |
;; |
682 |
|
|
683 |
--multiboot*) |
--multiboot*) |
684 |
if echo $1 |grep '=' >/dev/null |
if [[ $1 == --multiboot\=* ]] |
685 |
then |
then |
686 |
mbkernel=$(echo $1 | sed 's/^--multiboot=//') |
mbkernel=${1#--multiboot=} |
687 |
else |
else |
688 |
# can't really support having an optional second arg here |
# can't really support having an optional second arg here |
689 |
# sorry! |
# sorry! |
692 |
;; |
;; |
693 |
|
|
694 |
--mbargs*) |
--mbargs*) |
695 |
if echo $1 |grep '=' >/dev/null |
if [[ $1 == --mbargs\=* ]] |
696 |
then |
then |
697 |
mbargs=$(echo $1 | sed 's/^--mbargs=//') |
mbargs=${1#--mbargs=} |
698 |
else |
else |
699 |
mbargs="$2" |
mbargs="$2" |
700 |
shift |
shift |
713 |
makedefault="--make-default" |
makedefault="--make-default" |
714 |
;; |
;; |
715 |
|
|
716 |
--package) |
--package*) |
717 |
if echo $1 | grep '=' >/dev/null |
if [[ $1 == --package\=* ]] |
718 |
then |
then |
719 |
package=$(echo $1 | sed 's/^--package=//') |
package=${1#--package=} |
720 |
else |
else |
721 |
package=$2 |
package=$2 |
722 |
shift |
shift |
731 |
addplymouthinitrd=--add-plymouth-initrd |
addplymouthinitrd=--add-plymouth-initrd |
732 |
;; |
;; |
733 |
|
|
734 |
|
--kernel-image*) |
735 |
|
if [[ $1 == --kernel-image\=* ]] |
736 |
|
then |
737 |
|
kernelImage=${1#--kernel-image=} |
738 |
|
else |
739 |
|
kernelImage="$2" |
740 |
|
shift |
741 |
|
fi |
742 |
|
if ! [[ -f ${kernelImage} ]] |
743 |
|
then |
744 |
|
echo "Can't find kernel image '${kernelImage}'" >&2 |
745 |
|
usage |
746 |
|
exit 1 |
747 |
|
fi |
748 |
|
;; |
749 |
|
|
750 |
-v) |
-v) |
751 |
verbose=-v |
verbose=-v |
752 |
;; |
;; |
794 |
fi |
fi |
795 |
fi |
fi |
796 |
|
|
797 |
|
[[ ${kernelImage} ]] || kernelImage="${bootPrefix}/${kernelName}-${version}" |
798 |
|
|
799 |
# set the initrd file based on arch; ia64 is the only currently known oddball |
# set the initrd file based on arch; ia64 is the only currently known oddball |
800 |
if [[ -z ${initrdfile} ]] |
if [[ -z ${initrdfile} ]] |
801 |
then |
then |
817 |
# add dracut i18n, keyboard and plymouth kernel args if requested |
# add dracut i18n, keyboard and plymouth kernel args if requested |
818 |
if [[ -n ${dracut} ]] || [[ -n ${adddracutargs} ]] |
if [[ -n ${dracut} ]] || [[ -n ${adddracutargs} ]] |
819 |
then |
then |
820 |
[ -r /etc/conf.d/keymap ] && . /etc/conf.d/keymap |
if [ -r /etc/vconsole.conf ] |
|
[ -r /etc/conf.d/consolefont ] && . /etc/conf.d/consolefont |
|
|
|
|
|
if [[ -n ${KEYMAP} ]] |
|
821 |
then |
then |
822 |
kernargs="${kernargs} KEYTABLE=${KEYMAP}" |
. /etc/vconsole.conf |
823 |
|
|
824 |
|
for i in SYSFONT SYSFONTACM UNIMAP KEYTABLE |
825 |
|
do |
826 |
|
val=$(eval echo \$$i) |
827 |
|
[[ -n ${val} ]] && kernargs="${kernargs} ${i}=${val}" |
828 |
|
done |
829 |
|
else |
830 |
|
if [ -r /etc/conf.d/consolefont ] |
831 |
|
then |
832 |
|
. /etc/conf.d/consolefont |
833 |
|
|
834 |
|
if [[ -n ${CONSOLEFONT} ]] |
835 |
|
then |
836 |
|
kernargs="${kernargs} SYSFONT=${CONSOLEFONT}" |
837 |
|
fi |
838 |
|
fi |
839 |
|
|
840 |
|
if [ -r /etc/conf.d/keymap ] |
841 |
|
then |
842 |
|
. /etc/conf.d/keymap |
843 |
|
|
844 |
|
if [[ -n ${KEYMAP} ]] |
845 |
|
then |
846 |
|
kernargs="${kernargs} KEYTABLE=${KEYMAP}" |
847 |
|
fi |
848 |
|
fi |
849 |
fi |
fi |
850 |
|
|
851 |
if [[ -n ${CONSOLEFONT} ]] |
if [ -r /etc/locale.conf ] |
852 |
then |
then |
853 |
kernargs="${kernargs} SYSFONT=${CONSOLEFONT}" |
. /etc/locale.conf |
854 |
|
|
855 |
|
if [[ -n ${LANG} ]] |
856 |
|
then |
857 |
|
kernargs="${kernargs} LANG=${LANG}" |
858 |
|
fi |
859 |
fi |
fi |
860 |
fi |
fi |
861 |
|
|