79 |
grub2Config="" |
grub2Config="" |
80 |
grub2EfiConfig="" |
grub2EfiConfig="" |
81 |
extlinuxConfig="" |
extlinuxConfig="" |
82 |
|
ubootScript="/boot/boot.scr" |
83 |
|
|
84 |
ARCH=$(uname -m) |
ARCH=$(uname -m) |
85 |
|
|
117 |
then |
then |
118 |
liloConfig="" |
liloConfig="" |
119 |
bootPrefix=/boot |
bootPrefix=/boot |
120 |
|
extlinuxConfig=$(readlink -f /etc/extlinux.conf 2>/dev/null) |
121 |
ubootDir=${UBOOT_DIR:-"/boot"} |
ubootDir=${UBOOT_DIR:-"/boot"} |
122 |
ubootScript=$ubootDir/${UBOOT_SCR:-"boot.scr"} |
ubootScript=$ubootDir/${UBOOT_SCR:-"boot.scr"} |
123 |
ubootKList=${UBOOT_KLIST:-"klist.txt"} |
ubootKList=${UBOOT_KLIST:-"klist.txt"} |
146 |
dracut="" |
dracut="" |
147 |
dracuthostonly="" |
dracuthostonly="" |
148 |
initrdfile="" |
initrdfile="" |
149 |
|
devtreefile="" |
150 |
moddep="" |
moddep="" |
151 |
verbose="" |
verbose="" |
152 |
makedefault="" |
makedefault="" |
155 |
mbargs="${HYPERVISOR_ARGS}" |
mbargs="${HYPERVISOR_ARGS}" |
156 |
adddracutargs="" |
adddracutargs="" |
157 |
addplymouthinitrd="" |
addplymouthinitrd="" |
158 |
|
DEBUGARG="systemd.debug" |
159 |
|
|
160 |
usage() |
usage() |
161 |
{ |
{ |
165 |
echo " [--banner=<banner>] [--multiboot=multiboot]" >&2 |
echo " [--banner=<banner>] [--multiboot=multiboot]" >&2 |
166 |
echo " [--mbargs=mbargs] [--make-default] [--add-dracut-args]" >&2 |
echo " [--mbargs=mbargs] [--make-default] [--add-dracut-args]" >&2 |
167 |
echo " [--add-plymouth-initrd]" >&2 |
echo " [--add-plymouth-initrd]" >&2 |
168 |
echo " [--host-only]" >&2 |
echo " [--host-only] [--devtree=<devicetree.dtb>] [--devtreedir=</devicetree/path/>]" >&2 |
169 |
echo " <--install | --remove | --update> <kernel-version>" >&2 |
echo " <--install | --remove | --update> <kernel-version>" >&2 |
170 |
echo " (ex: $(basename $0) --mkinitrd --depmod --install 2.4.7-2)" >&2 |
echo " (ex: $(basename $0) --mkinitrd --depmod --install 2.4.7-2)" >&2 |
171 |
exit 1 |
exit 1 |
172 |
} |
} |
173 |
|
|
174 |
|
rungrubby() |
175 |
|
{ |
176 |
|
if [[ $1 == --debug ]] |
177 |
|
then |
178 |
|
[[ ${MAKEDEBUG} != yes ]] && return 0 |
179 |
|
[[ -n ${verbose} ]] && echo "- First, making a debug entry." |
180 |
|
declare -x debugtitle=" with debugging" |
181 |
|
declare -x debugargs="${DEBUGARG}" |
182 |
|
shift |
183 |
|
else |
184 |
|
[[ -n ${verbose} ] && echo "- Making a normal entry." |
185 |
|
fi |
186 |
|
$(eval $grubby $@) |
187 |
|
export -n debugargs |
188 |
|
export -n debugtitle |
189 |
|
unset debugargs |
190 |
|
unset debugtitle |
191 |
|
} |
192 |
|
|
193 |
|
set_title() |
194 |
|
{ |
195 |
|
if [[ -n ${banner} ]] |
196 |
|
then |
197 |
|
if [[ ${ARCH} = s390 ]] || [[ ${ARCH} = s390x ]] |
198 |
|
then |
199 |
|
title=$(echo ${banner} | sed 's/ /_/g') |
200 |
|
else |
201 |
|
title="${banner} [ ${version} ]" |
202 |
|
fi |
203 |
|
elif [[ ${ARCH} = s390 ]] || [[ ${ARCH} = s390x ]] |
204 |
|
then |
205 |
|
title=$(echo ${version} | sed 's/ /_/g') |
206 |
|
elif [ -f /etc/os-release ] |
207 |
|
then |
208 |
|
title="$(read_os_release name) $(read_os_release version_id) [ ${version} ]" |
209 |
|
elif [ -f /etc/mageversion ] |
210 |
|
then |
211 |
|
title="Magellan Linux $(< /etc/mageversion) [ ${version} ]" |
212 |
|
else |
213 |
|
title="Magellan Linux [ ${version} ]" |
214 |
|
fi |
215 |
|
} |
216 |
|
|
217 |
install() |
install() |
218 |
{ |
{ |
219 |
# 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) |
220 |
if [ ! -f ${bootPrefix}/${kernelName}-${version} ] |
if [ ! -f ${kernelImage} ] |
221 |
then |
then |
222 |
[[ -n ${verbose} ]] && echo "kernel for ${version} does not exist, not running grubby" |
[[ -n ${verbose} ]] && echo "kernel for ${version} does not exist, not running grubby" |
223 |
return |
return |
235 |
fi |
fi |
236 |
fi |
fi |
237 |
|
|
238 |
|
DEVTREE="" |
239 |
|
if [[ -n ${devtreefile} ]] && [ -f ${devtreefile} ] |
240 |
|
then |
241 |
|
[[ -n ${verbose} ]] && echo "found ${devtreefile} and using it with grubby" |
242 |
|
DEVTREE="--devtree ${devtreefile}" |
243 |
|
fi |
244 |
|
|
245 |
|
DEVTREEDIR="" |
246 |
|
if [[ -n ${devtreedir} ]] && [ -d ${devtreedir} ] |
247 |
|
then |
248 |
|
[ -n ${verbose} ] && echo "found ${devtreedir} and using it with grubby" |
249 |
|
DEVTREEDIR="--devtreedir ${devtreedir}" |
250 |
|
fi |
251 |
|
|
252 |
# 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? |
253 |
if [ -d /proc/iSeries ] |
if [ -d /proc/iSeries ] |
254 |
then |
then |
256 |
if [[ -z ${initrdfile} ]] |
if [[ -z ${initrdfile} ]] |
257 |
then |
then |
258 |
[[ -n ${verbose} ]] && echo "No initrd, just adding system map" |
[[ -n ${verbose} ]] && echo "No initrd, just adding system map" |
259 |
/sbin/addSystemMap ${bootPrefix}/System.map-${version} ${bootPrefix}/${kernelName}-${version} ${bootPrefix}/vmlinitrd-${version} |
/sbin/addSystemMap ${bootPrefix}/System.map-${version} ${kernelImage} ${bootPrefix}/vmlinitrd-${version} |
260 |
else |
else |
261 |
/sbin/addSystemMap ${bootPrefix}/System.map-${version} ${bootPrefix}/${kernelName}-${version} ${bootPrefix}/vmlinux.sm-${version} |
/sbin/addSystemMap ${bootPrefix}/System.map-${version} ${kernelImage} ${bootPrefix}/vmlinux.sm-${version} |
262 |
/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 |
263 |
rm ${bootPrefix}/vmlinux.sm-${version} |
rm ${bootPrefix}/vmlinux.sm-${version} |
264 |
fi |
fi |
266 |
fi |
fi |
267 |
|
|
268 |
# get the root filesystem to use |
# get the root filesystem to use |
269 |
rootdevice=$(awk '{ if ($1 !~ /^[ \t]*#/ && $2 == "/") { print $1; }}' /etc/fstab) |
rootdevice=$(awk '{ if ($1 !~ /^[ \t]*#/ && $2 == "/") { print $1; }}' /etc/fstab 2>/dev/null) |
270 |
if [[ -z $rootdevice ]] |
if [[ -z $rootdevice ]] |
271 |
then |
then |
272 |
rootdevice=$(grep -o -P "(?<=root=)\S+" /proc/cmdline) |
rootdevice=$(grep -o -P "(?<=root=)\S+" /proc/cmdline) |
278 |
cfgLilo="" |
cfgLilo="" |
279 |
fi |
fi |
280 |
|
|
281 |
|
set_title |
282 |
|
|
283 |
if [[ -n ${cfgGrub} ]] |
if [[ -n ${cfgGrub} ]] |
284 |
then |
then |
285 |
[[ -n ${verbose} ]] && echo "adding ${version} to ${grubConfig}" |
[[ -n ${verbose} ]] && echo "adding ${version} to ${grubConfig}" |
286 |
|
|
287 |
if [[ -n ${banner} ]] |
ARGS="--grub -c ${grubConfig} --add-kernel=${kernelImage} ${INITRD} \ |
288 |
then |
${mbkernel:+--add-multiboot=\"${mbkernel}\"} \ |
289 |
title="${banner} [ ${version} ]" |
${mbargs:+--mbargs=\"${mbargs}\"} \ |
290 |
elif [ -f /etc/mageversion ] |
--title=\"${title}\${debugtitle}\" --copy-default \ |
291 |
then |
--args=\"root=${rootdevice} ${kernargs} \${debugargs}\" \ |
292 |
title="Magellan Linux $(< /etc/mageversion) [ ${version} ]" |
--remove-kernel=\"TITLE=${title}\${debugtitle}\"" |
293 |
elif [[ $(read_os_release id) = magellan ]] |
rungrubby --debug ${ARGS} |
294 |
then |
rungrubby ${ARGS} ${makedefault} |
|
title="$(read_os_release name) $(read_os_release version_id) [ ${version} ]" |
|
|
else |
|
|
title="Magellan Linux [ ${version} ]" |
|
|
fi |
|
|
${grubby} --grub -c ${grubConfig} \ |
|
|
--add-kernel=${bootPrefix}/${kernelName}-${version} \ |
|
|
${INITRD} --copy-default ${makedefault} --title "${title}" \ |
|
|
${mbkernel:+--add-multiboot="${mbkernel}"} ${mbargs:+--mbargs="${mbargs}"} \ |
|
|
--args="root=${rootdevice} ${kernargs}" --remove-kernel="TITLE=${title}" |
|
295 |
else |
else |
296 |
[[ -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" |
297 |
fi |
fi |
299 |
then |
then |
300 |
[[ -n ${verbose} ]] && echo "adding ${version} to ${grub2Config}" |
[[ -n ${verbose} ]] && echo "adding ${version} to ${grub2Config}" |
301 |
|
|
302 |
if [[ -n ${banner} ]] |
ARGS="--grub2 -c ${grub2Config} --add-kernel=${kernelImage} ${INITRD} \ |
303 |
then |
--copy-default --title \"${title}\${debugtitle}\" \ |
304 |
title="${banner} [ ${version} ]" |
${mbkernel:+--add-multiboot=\"${mbkernel}\"} \ |
305 |
elif [ -f /etc/mageversion ] |
${mbargs:+--mbargs=\"${mbargs}\"} \ |
306 |
then |
--args=\"root=${rootdevice} ${kernargs} \${debugargs}\" \ |
307 |
title="Magellan Linux $(< /etc/mageversion) [ ${version} ]" |
--remove-kernel=\"TITLE=${title}\${debugtitle}\"" |
308 |
elif [[ $(read_os_release id) = magellan ]] |
rungrubby --debug ${ARGS} |
309 |
then |
rungrubby ${ARGS} ${makedefault} |
|
title="$(read_os_release name) $(read_os_release version_id) [ ${version} ]" |
|
|
else |
|
|
title="Magellan Linux [ ${version} ]" |
|
|
fi |
|
|
${grubby} --grub2 -c ${grub2Config} \ |
|
|
--add-kernel=${bootPrefix}/${kernelName}-${version} \ |
|
|
${INITRD} --copy-default ${makedefault} --title "${title}" \ |
|
|
${mbkernel:+--add-multiboot="${mbkernel}"} \ |
|
|
${mbargs:+--mbargs="${mbargs}"} \ |
|
|
--args="root=${rootdevice} ${kernargs}" --remove-kernel="TITLE=${title}" |
|
310 |
else |
else |
311 |
[[ -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" |
312 |
fi |
fi |
314 |
then |
then |
315 |
[[ -n ${verbose} ]] && echo "adding ${version} to ${grub2EfiConfig}" |
[[ -n ${verbose} ]] && echo "adding ${version} to ${grub2EfiConfig}" |
316 |
|
|
317 |
if [[ -n ${banner} ]] |
ARGS="--grub2 -c ${grub2EfiConfig} --efi \ |
318 |
then |
--add-kernel=${kernelImage} ${DEVTREE} ${INITRD} \ |
319 |
title="${banner} [ ${version} ]" |
--copy-default --title \"${title}\${debugtitle}\" \ |
320 |
elif [ -f /etc/mageversion ] |
${mbkernel:+--add-multiboot=\"${mbkernel}\"} \ |
321 |
then |
${mbargs:+--mbargs=\"${mbargs}\"} \ |
322 |
title="Magellan Linux $(< /etc/mageversion) [ ${version} ]" |
--args=\"root=${rootdevice} ${kernargs} \${debugargs}\" \ |
323 |
elif [[ $(read_os_release id) = magellan ]] |
--remove-kernel=\"TITLE=${title}\${debugtitle}\"" |
324 |
then |
rungrubby --debug ${ARGS} |
325 |
title="$(read_os_release name) $(read_os_release version_id) [ ${version} ]" |
rungrubby ${ARGS} ${makedefault} |
|
else |
|
|
title="Magellan Linux [ ${version} ]" |
|
|
fi |
|
|
${grubby} --grub2 -c ${grub2EfiConfig} --efi \ |
|
|
--add-kernel=${bootPrefix}/${kernelName}-${version} \ |
|
|
${INITRD} --copy-default ${makedefault} --title "${title}" \ |
|
|
${mbkernel:+--add-multiboot="${mbkernel}"} \ |
|
|
${mbargs:+--mbargs="${mbargs}"} \ |
|
|
--args="root=${rootdevice} ${kernargs}" --remove-kernel="TITLE=${title}" |
|
326 |
else |
else |
327 |
[[ -n ${verbose} ]] && echo "${grub2EfiConfig} does not exist, not running grubby for grub 2 with UEFI" |
[[ -n ${verbose} ]] && echo "${grub2EfiConfig} does not exist, not running grubby for grub 2 with UEFI" |
328 |
fi |
fi |
331 |
then |
then |
332 |
[[ -n ${verbose} ]] && echo "adding ${version} to ${liloConfig}" |
[[ -n ${verbose} ]] && echo "adding ${version} to ${liloConfig}" |
333 |
|
|
334 |
${grubby} --add-kernel=${bootPrefix}/${kernelName}-${version} ${INITRD} \ |
ARGS="--${liloFlag} --add-kernel=${kernelImage} ${INITRD} \ |
335 |
--copy-default ${makedefault} --title ${version} \ |
--copy-default --title \"${title}\${debugtitle}\" \ |
336 |
${mbkernel:+--add-multiboot="${mbkernel}"} ${mbargs:+--mbargs="${mbargs}"} \ |
${mbkernel:+--add-multiboot=\"${mbkernel}\"} \ |
337 |
--args="root=${rootdevice} ${kernargs}" --remove-kernel="TITLE=${version}" \ |
${mbargs:+--mbargs=\"${mbargs}\"} \ |
338 |
--${liloFlag} |
--args=\"root=${rootdevice} ${kernargs} \${debugargs}\" \ |
339 |
|
--remove-kernel=\"TITLE=${version}\"" |
340 |
|
rungrubby --debug ${ARGS} |
341 |
|
rungrubby ${ARGS} ${makedefault} |
342 |
|
|
343 |
if [[ -n ${runLilo} ]] |
if [[ -n ${runLilo} ]] |
344 |
then |
then |
358 |
then |
then |
359 |
[[ -n ${verbose} ]] && echo "adding ${version} to ${extlinuxConfig}" |
[[ -n ${verbose} ]] && echo "adding ${version} to ${extlinuxConfig}" |
360 |
|
|
361 |
if [[ -n ${banner} ]] |
ARGS="--extlinux -c ${extlinuxConfig} --add-kernel=${kernelImage} \ |
362 |
then |
${DEVTREEDIR} ${DEVTREE} \ |
363 |
title="${banner} [ ${version} ]" |
${INITRD} --copy-default --title \"${title}\${debugtitle}\" \ |
364 |
elif [ -f /etc/mageversion ] |
${mbkernel:+--add-multiboot=\"${mbkernel}\"} \ |
365 |
then |
${mbargs:+--mbargs=\"${mbargs}\"} \ |
366 |
title="Magellan Linux $(< /etc/mageversion) [ ${version} ]" |
--args=\"root=${rootdevice} ${kernargs} \${debugargs}\" \ |
367 |
elif [[ $(read_os_release id) = magellan ]] |
--remove-kernel=\"TITLE=${title}\${debugtitle}\"" |
368 |
then |
rungrubby --debug ${ARGS} |
369 |
title="$(read_os_release name) $(read_os_release version_id) [ ${version} ]" |
rungrubby ${ARGS} ${makedefault} |
|
else |
|
|
title="Magellan Linux [ ${version} ]" |
|
|
fi |
|
|
${grubby} --extlinux -c ${extlinuxConfig} \ |
|
|
--add-kernel=${bootPrefix}/${kernelName}-${version} \ |
|
|
${INITRD} --copy-default ${makedefault} --title "${title}" \ |
|
|
${mbkernel:+--add-multiboot="${mbkernel}"} ${mbargs:+--mbargs="${mbargs}"} \ |
|
|
--args="root=${rootdevice} ${kernargs}" --remove-kernel="TITLE=${title}" |
|
370 |
else |
else |
371 |
[[ -n ${verbose} ]] && echo "${extlinuxConfig} does not exist, not running grubby for extlinux" |
[[ -n ${verbose} ]] && echo "${extlinuxConfig} does not exist, not running grubby for extlinux" |
372 |
fi |
fi |
378 |
if [ -d /proc/iSeries ] |
if [ -d /proc/iSeries ] |
379 |
then |
then |
380 |
[[ -n ${verbose} ]] && echo "On an iSeries, remove img file" |
[[ -n ${verbose} ]] && echo "On an iSeries, remove img file" |
381 |
rm -f ${bootPrefix}/${kernelName}-${version}.img 2>/dev/null |
rm -f ${kernelImage}.img 2>/dev/null |
382 |
return |
return |
383 |
fi |
fi |
384 |
|
|
386 |
then |
then |
387 |
[[ -n ${verbose} ]] && echo "removing ${version} from ${grubConfig}" |
[[ -n ${verbose} ]] && echo "removing ${version} from ${grubConfig}" |
388 |
${grubby} --grub -c ${grubConfig} \ |
${grubby} --grub -c ${grubConfig} \ |
389 |
--remove-kernel=${bootPrefix}/${kernelName}-${version} |
--remove-kernel=${kernelImage} |
390 |
else |
else |
391 |
[[ -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" |
392 |
fi |
fi |
394 |
then |
then |
395 |
[[ -n ${verbose} ]] && echo "removing ${version} from ${grub2Config}" |
[[ -n ${verbose} ]] && echo "removing ${version} from ${grub2Config}" |
396 |
${grubby} --grub2 -c ${grub2Config} \ |
${grubby} --grub2 -c ${grub2Config} \ |
397 |
--remove-kernel=${bootPrefix}/${kernelName}-${version} |
--remove-kernel=${kernelImage} |
398 |
else |
else |
399 |
[[ -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" |
400 |
fi |
fi |
402 |
then |
then |
403 |
[[ -n ${verbose} ]] && echo "removing ${version} from ${grub2EfiConfig}" |
[[ -n ${verbose} ]] && echo "removing ${version} from ${grub2EfiConfig}" |
404 |
${grubby} --grub2 -c ${grub2EfiConfig} --efi \ |
${grubby} --grub2 -c ${grub2EfiConfig} --efi \ |
405 |
--remove-kernel=${bootPrefix}/${kernelName}-${version} |
--remove-kernel=${kernelImage} |
406 |
else |
else |
407 |
[[ -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" |
408 |
fi |
fi |
410 |
if [[ -n ${cfgLilo} ]] |
if [[ -n ${cfgLilo} ]] |
411 |
then |
then |
412 |
[[ -n ${verbose} ]] && echo "removing ${version} from ${liloConfig}" |
[[ -n ${verbose} ]] && echo "removing ${version} from ${liloConfig}" |
413 |
${grubby} --remove-kernel=${bootPrefix}/${kernelName}-${version} --${liloFlag} |
${grubby} --remove-kernel=${kernelImage} --${liloFlag} |
414 |
|
|
415 |
if [[ -n ${runLilo} ]] |
if [[ -n ${runLilo} ]] |
416 |
then |
then |
469 |
fi |
fi |
470 |
|
|
471 |
mv ${tmpKList} ${ubootDir}/${ubootKList} |
mv ${tmpKList} ${ubootDir}/${ubootKList} |
472 |
|
[ -x /sbin/a-b-c ] && /sbin/a-b-c |
473 |
else |
else |
474 |
[[ -n ${verbose} ]] && echo "uImage ${newversion} does not exist!" |
[[ -n ${verbose} ]] && echo "uImage ${newversion} does not exist!" |
475 |
[ -f ${tmpKList} ] && rm -f ${tmpKList} |
[ -f ${tmpKList} ] && rm -f ${tmpKList} |
485 |
then |
then |
486 |
[[ -n ${verbose} ]] && echo "removing ${version} from ${extlinuxConfig}" |
[[ -n ${verbose} ]] && echo "removing ${version} from ${extlinuxConfig}" |
487 |
${grubby} --extlinux -c ${extlinuxConfig} \ |
${grubby} --extlinux -c ${extlinuxConfig} \ |
488 |
--remove-kernel=${bootPrefix}/${kernelName}-${version} |
--remove-kernel=${kernelImage} |
489 |
else |
else |
490 |
[[ -n ${verbose} ]] && echo "${extlinuxConfig} does not exist, not running grubby for extlinux" |
[[ -n ${verbose} ]] && echo "${extlinuxConfig} does not exist, not running grubby for extlinux" |
491 |
fi |
fi |
493 |
|
|
494 |
update() |
update() |
495 |
{ |
{ |
496 |
if [ ! -f ${bootPrefix}/${kernelName}-${version} ] |
if [ ! -f ${kernelImage} ] |
497 |
then |
then |
498 |
[[ -n ${verbose} ]] && echo "kernel for ${version} does not exist, not running grubby" |
[[ -n ${verbose} ]] && echo "kernel for ${version} does not exist, not running grubby" |
499 |
return |
return |
500 |
fi |
fi |
501 |
|
|
502 |
|
set_title |
503 |
|
|
504 |
INITRD="" |
INITRD="" |
505 |
if [ -f ${initrdfile} ] |
if [ -f ${initrdfile} ] |
506 |
then |
then |
513 |
fi |
fi |
514 |
fi |
fi |
515 |
|
|
516 |
|
DEVTREE="" |
517 |
|
if [[ -n ${devtreefile} ]] && [ -f ${devtreefile} ] |
518 |
|
then |
519 |
|
[[ -n ${verbose} ]] && echo "found ${devtreefile} and using it with grubby" |
520 |
|
DEVTREE="--devtree ${devtreefile}" |
521 |
|
fi |
522 |
|
|
523 |
|
DEVTREEDIR="" |
524 |
|
if [[ -n ${devtreedir} ]] && [ -d ${devtreedir} ] |
525 |
|
then |
526 |
|
[[ -n ${verbose} ]] && echo "found ${devtreedir} and using it with grubby" |
527 |
|
DEVTREEDIR="--devtreedir ${devtreedir}" |
528 |
|
fi |
529 |
|
|
530 |
if [[ -n ${cfgGrub} ]] |
if [[ -n ${cfgGrub} ]] |
531 |
then |
then |
532 |
[[ -n ${verbose} ]] && echo "updating ${version} from ${grubConfig}" |
[[ -n ${verbose} ]] && echo "updating ${version} from ${grubConfig}" |
533 |
${grubby} --grub -c ${grubConfig} \ |
ARGS="--grub -c ${grubConfig} --update-kernel=${kernelImage} ${INITRD} \ |
534 |
--update-kernel=${bootPrefix}/${kernelName}-${version} \ |
${kernargs:+--args=\"${kernargs}\"} \ |
535 |
${INITRD} \ |
${removeargs:+--remove-args=\"${removeargs}\"} \ |
536 |
${kernargs:+--args="${kernargs}"} \ |
${mbkernel:+--add-multiboot=\"${mbkernel}\"} \ |
537 |
${removeargs:+--remove-args="${removeargs}"} |
--title=\"${title}\${debugtitle}\"" |
538 |
|
rungrubby --debug ${ARGS} |
539 |
|
rungrubby ${ARGS} |
540 |
else |
else |
541 |
[[ -n ${verbose} ]] && echo "${grubConfig} does not exist, not running grubby" |
[[ -n ${verbose} ]] && echo "${grubConfig} does not exist, not running grubby" |
542 |
fi |
fi |
544 |
if [[ -n ${cfgGrub2} ]] |
if [[ -n ${cfgGrub2} ]] |
545 |
then |
then |
546 |
[[ -n ${verbose} ]] && echo "updating ${version} from ${grub2Config}" |
[[ -n ${verbose} ]] && echo "updating ${version} from ${grub2Config}" |
547 |
${grubby} --grub2 -c ${grub2Config} \ |
ARGS="--grub2 -c ${grub2Config} --update-kernel=${kernelImage} ${INITRD} \ |
548 |
--update-kernel=${bootPrefix}/${kernelName}-${version} \ |
${kernargs:+--args=\"${kernargs}\"} \ |
549 |
${INITRD} \ |
${removeargs:+--remove-args=\"${removeargs}\"} \ |
550 |
${kernargs:+--args="${kernargs}"} \ |
--title=\"${title}\${debugtitle}\"" |
551 |
${removeargs:+--remove-args="${removeargs}"} |
rungrubby --debug ${ARGS} |
552 |
|
rungrubby ${ARGS} |
553 |
else |
else |
554 |
[[ -n ${verbose} ]] && echo "${grub2Config} does not exist, not running grubby" |
[[ -n ${verbose} ]] && echo "${grub2Config} does not exist, not running grubby" |
555 |
fi |
fi |
557 |
if [[ -n ${cfgGrub2Efi} ]] |
if [[ -n ${cfgGrub2Efi} ]] |
558 |
then |
then |
559 |
[[ -n ${verbose} ]] && echo "updating ${version} from ${grub2EfiConfig}" |
[[ -n ${verbose} ]] && echo "updating ${version} from ${grub2EfiConfig}" |
560 |
${grubby} --grub2 -c ${grub2EfiConfig} --efi \ |
ARGS="--grub2 -c ${grub2EfiConfig} --efi --update-kernel=${kernelImage} \ |
561 |
--update-kernel=${bootPrefix}/${kernelName}-${version} \ |
${INITRD} ${kernargs:+--args=\"${kernargs}\"} \ |
562 |
${INITRD} \ |
${removeargs:+--remove-args=\"${removeargs}\"} \ |
563 |
${kernargs:+--args="${kernargs}"} \ |
--title=\"${title}\${debugtitle}\"" |
564 |
${removeargs:+--remove-args="${removeargs}"} |
rungrubby --debug ${ARGS} |
565 |
|
rungrubby ${ARGS} |
566 |
else |
else |
567 |
[[ -n ${verbose} ]] && echo "${grub2EfiConfig} does not exist, not running grubby" |
[[ -n ${verbose} ]] && echo "${grub2EfiConfig} does not exist, not running grubby" |
568 |
fi |
fi |
570 |
if [[ -n ${cfgLilo} ]] |
if [[ -n ${cfgLilo} ]] |
571 |
then |
then |
572 |
[[ -n ${verbose} ]] && echo "updating ${version} from ${liloConfig}" |
[[ -n ${verbose} ]] && echo "updating ${version} from ${liloConfig}" |
573 |
${grubby} --update-kernel=${bootPrefix}/${kernelName}-${version} \ |
ARGS="--${liloFlag} --update-kernel=${kernelImage} ${INITRD} \ |
574 |
${INITRD} \ |
${kernargs:+--args=\"${kernargs}\"} \ |
575 |
${kernargs:+--args="${kernargs}"} \ |
${removeargs:+--remove-args=\"${removeargs}\"} \ |
576 |
${removeargs:+--remove-args="${removeargs}"} \ |
--title=\"${title}\${debugtitle}\"" |
577 |
--${liloFlag} |
rungrubby --debug ${ARGS} |
578 |
|
rungrubby ${ARGS} |
579 |
|
|
580 |
if [[ -n ${runLilo} ]] |
if [[ -n ${runLilo} ]] |
581 |
then |
then |
598 |
[[ -n ${verbose} ]] && echo "creating uImage-${version}" |
[[ -n ${verbose} ]] && echo "creating uImage-${version}" |
599 |
mkimage -A arm -O linux -T kernel -C none -a ${ubootAddress} \ |
mkimage -A arm -O linux -T kernel -C none -a ${ubootAddress} \ |
600 |
-e ${ubootAddress} -n ${version} \ |
-e ${ubootAddress} -n ${version} \ |
601 |
-d ${bootPrefix}/${kernelName}-${version} ${ubootDir}/uImage-${version} |
-d ${kernelImage} ${ubootDir}/uImage-${version} |
602 |
|
|
603 |
[[ -n ${verbose} ]] && echo "creating uInitrd-${version}" |
[[ -n ${verbose} ]] && echo "creating uInitrd-${version}" |
604 |
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 \ |
617 |
[[ -n ${verbose} ]] && echo "copy uInitrd-${version} error, kernel not installed!" && exit |
[[ -n ${verbose} ]] && echo "copy uInitrd-${version} error, kernel not installed!" && exit |
618 |
fi |
fi |
619 |
echo ${version} >> ${ubootDir}/${ubootKList} |
echo ${version} >> ${ubootDir}/${ubootKList} |
620 |
|
[ -x /sbin/a-b-c ] && /sbin/a-b-c |
621 |
else |
else |
622 |
[[ -n ${verbose} ]] && echo "cannot make ${version} the default" |
[[ -n ${verbose} ]] && echo "cannot make ${version} the default" |
623 |
fi |
fi |
628 |
if [[ -n ${cfgExtlinux} ]] |
if [[ -n ${cfgExtlinux} ]] |
629 |
then |
then |
630 |
[[ -n ${verbose} ]] && echo "updating ${version} from ${extlinuxConfig}" |
[[ -n ${verbose} ]] && echo "updating ${version} from ${extlinuxConfig}" |
631 |
${grubby} --extlinux -c ${extlinuxConfig} \ |
ARGS="--extlinux -c ${extlinuxConfig} --update-kernel=${kernelImage} \ |
632 |
--update-kernel=${bootPrefix}/${kernelName}-${version} \ |
${DEVTREE} ${DEVTREEDIR} ${INITRD} ${kernargs:+--args=\"${kernargs}\"} \ |
633 |
${INITRD} \ |
${removeargs:+--remove-args=\"${removeargs}\"} \ |
634 |
${kernargs:+--args="${kernargs}"} \ |
--title=\"${title}\${debugtitle}\"" |
635 |
${removeargs:+--remove-args="${removeargs}"} |
rungrubby --debug ${ARGS} |
636 |
|
rungrubby ${ARGS} |
637 |
else |
else |
638 |
[[ -n ${verbose} ]] && echo "${extlinuxConfig} does not exist, not running grubby" |
[[ -n ${verbose} ]] && echo "${extlinuxConfig} does not exist, not running grubby" |
639 |
fi |
fi |
672 |
doRmmoddep() |
doRmmoddep() |
673 |
{ |
{ |
674 |
[[ -n ${verbose} ]] && echo "removing modules.dep info for ${version}" |
[[ -n ${verbose} ]] && echo "removing modules.dep info for ${version}" |
675 |
[ -d /lib/modules/${version} ] && rm -f /lib/modules/${version}/modules.* |
if [ -d /lib/modules/${version} ] |
676 |
|
then |
677 |
|
rm -f /lib/modules/${version}/modules.*.bin \ |
678 |
|
/lib/modules/${version}/modules.{alias,dep,devname,symbols,softdep} |
679 |
|
fi |
680 |
} |
} |
681 |
|
|
682 |
|
# kernel image for 2.4 is kernel |
683 |
|
if [[ ${ARCH} = ppc64 ]] || [[ ${ARCH} = ppc ]] |
684 |
|
then |
685 |
|
if [[ ${kernelmajor} = 2.4 ]] |
686 |
|
then |
687 |
|
kernelName=kernel |
688 |
|
fi |
689 |
|
fi |
690 |
|
|
691 |
while [ $# -gt 0 ] |
while [ $# -gt 0 ] |
692 |
do |
do |
699 |
initrd="remove" |
initrd="remove" |
700 |
;; |
;; |
701 |
|
|
702 |
|
--devtree*) |
703 |
|
if [[ $1 == --devtree\=* ]] |
704 |
|
then |
705 |
|
devtreefile="${1#--devtreefile=}" |
706 |
|
else |
707 |
|
devtreefile="$2" |
708 |
|
shift |
709 |
|
fi |
710 |
|
;; |
711 |
|
|
712 |
|
--devtreedir*) |
713 |
|
if [[ $1 == --devtreedir\=* ]] |
714 |
|
then |
715 |
|
devtreedir=${1#--devtreedir=} |
716 |
|
else |
717 |
|
devtreedir=$2 |
718 |
|
shift |
719 |
|
fi |
720 |
|
;; |
721 |
|
|
722 |
--dracut) |
--dracut) |
723 |
dracut=--dracut |
dracut=--dracut |
724 |
;; |
;; |
728 |
;; |
;; |
729 |
|
|
730 |
--initrdfile*) |
--initrdfile*) |
731 |
if echo $1 | grep '=' >/dev/null |
if [[ $1 == --initrdfile\=* ]] |
732 |
then |
then |
733 |
initrdfile=$(echo $1 | sed 's/^--initrdfile=//') |
initrdfile=${1#--initrdfile=} |
734 |
else |
else |
735 |
initrdfile=$2 |
initrdfile=$2 |
736 |
shift |
shift |
738 |
;; |
;; |
739 |
|
|
740 |
--kernel-args*) |
--kernel-args*) |
741 |
if echo $1 | grep '=' >/dev/null |
if [[ $1 == --kernel-args\=* ]] |
742 |
then |
then |
743 |
kernargs=$(echo $1 | sed 's/^--kernel-args=//') |
kernargs=${1#--kernel-args=} |
744 |
else |
else |
745 |
kernargs=$2 |
kernargs=$2 |
746 |
shift |
shift |
748 |
;; |
;; |
749 |
|
|
750 |
--remove-args*) |
--remove-args*) |
751 |
if echo $1 | grep '=' >/dev/null |
if [[ $1 == --remove-args\=* ]] |
752 |
then |
then |
753 |
removeargs=$(echo $1 | sed 's/^--remove-args=//') |
removeargs=${1#--remove-args=} |
754 |
else |
else |
755 |
removeargs=$2 |
removeargs=$2 |
756 |
shift |
shift |
758 |
;; |
;; |
759 |
|
|
760 |
--banner*) |
--banner*) |
761 |
if echo $1 | grep '=' >/dev/null |
if [[ $1 == --banner\=* ]] |
762 |
then |
then |
763 |
banner=$(echo $1 | sed 's/^--banner=//') |
banner=${1#--banner=} |
764 |
else |
else |
765 |
banner=$2 |
banner=$2 |
766 |
shift |
shift |
768 |
;; |
;; |
769 |
|
|
770 |
--multiboot*) |
--multiboot*) |
771 |
if echo $1 |grep '=' >/dev/null |
if [[ $1 == --multiboot\=* ]] |
772 |
then |
then |
773 |
mbkernel=$(echo $1 | sed 's/^--multiboot=//') |
mbkernel=${1#--multiboot=} |
774 |
else |
else |
775 |
# can't really support having an optional second arg here |
# can't really support having an optional second arg here |
776 |
# sorry! |
# sorry! |
779 |
;; |
;; |
780 |
|
|
781 |
--mbargs*) |
--mbargs*) |
782 |
if echo $1 |grep '=' >/dev/null |
if [[ $1 == --mbargs\=* ]] |
783 |
then |
then |
784 |
mbargs=$(echo $1 | sed 's/^--mbargs=//') |
mbargs=${1#--mbargs=} |
785 |
else |
else |
786 |
mbargs="$2" |
mbargs="$2" |
787 |
shift |
shift |
800 |
makedefault="--make-default" |
makedefault="--make-default" |
801 |
;; |
;; |
802 |
|
|
803 |
--package) |
--package*) |
804 |
if echo $1 | grep '=' >/dev/null |
if [[ $1 == --package\=* ]] |
805 |
then |
then |
806 |
package=$(echo $1 | sed 's/^--package=//') |
package=${1#--package=} |
807 |
else |
else |
808 |
package=$2 |
package=$2 |
809 |
shift |
shift |
818 |
addplymouthinitrd=--add-plymouth-initrd |
addplymouthinitrd=--add-plymouth-initrd |
819 |
;; |
;; |
820 |
|
|
821 |
|
--kernel-image*) |
822 |
|
if [[ $1 == --kernel-image\=* ]] |
823 |
|
then |
824 |
|
kernelImage=${1#--kernel-image=} |
825 |
|
else |
826 |
|
kernelImage="$2" |
827 |
|
shift |
828 |
|
fi |
829 |
|
if ! [[ -f ${kernelImage} ]] |
830 |
|
then |
831 |
|
echo "Can't find kernel image '${kernelImage}'" >&2 |
832 |
|
usage |
833 |
|
exit 1 |
834 |
|
fi |
835 |
|
;; |
836 |
|
|
837 |
|
--kernel-name*) |
838 |
|
if [[ $1 == --kernel-name\=* ]] |
839 |
|
then |
840 |
|
kernelName=${1#--kernel-name=} |
841 |
|
else |
842 |
|
kernelName="$2" |
843 |
|
shift |
844 |
|
fi |
845 |
|
;; |
846 |
|
|
847 |
-v) |
-v) |
848 |
verbose=-v |
verbose=-v |
849 |
;; |
;; |
882 |
|
|
883 |
kernelmajor=$(echo ${kernel} | cut -d . -f 1,2) |
kernelmajor=$(echo ${kernel} | cut -d . -f 1,2) |
884 |
|
|
885 |
# kernel image for 2.4 is kernel |
[[ ${kernelImage} ]] || kernelImage="${bootPrefix}/${kernelName}-${version}" |
|
if [[ ${ARCH} = ppc64 ]] || [[ ${ARCH} = ppc ]] |
|
|
then |
|
|
if [[ ${kernelmajor} = 2.4 ]] |
|
|
then |
|
|
kernelName=kernel |
|
|
fi |
|
|
fi |
|
886 |
|
|
887 |
# 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 |
888 |
if [[ -z ${initrdfile} ]] |
if [[ -z ${initrdfile} ]] |
902 |
fi |
fi |
903 |
[[ -n ${verbose} ]] && echo "initrdfile is ${initrdfile}" |
[[ -n ${verbose} ]] && echo "initrdfile is ${initrdfile}" |
904 |
|
|
905 |
|
if [[ ${ARCH} =~ armv[5|7].*l ]] |
906 |
|
then |
907 |
|
if [ -d ${bootPrefix}/dtb-${version}/ ] |
908 |
|
then |
909 |
|
devtreedir="${bootPrefix}/dtb-${version}/" |
910 |
|
if [[ -n ${dtbfile} ]] && [ -f ${devtreedir}/${dtbfile} ] |
911 |
|
then |
912 |
|
devtreefile="${devtreedir}/${dtbfile}" |
913 |
|
fi |
914 |
|
fi |
915 |
|
fi |
916 |
|
[[ -n ${verbose} ]] && echo "devtreedir is ${devtreedir}" |
917 |
|
|
918 |
# add dracut i18n, keyboard and plymouth kernel args if requested |
# add dracut i18n, keyboard and plymouth kernel args if requested |
919 |
if [[ -n ${dracut} ]] || [[ -n ${adddracutargs} ]] |
if [[ -n ${dracut} ]] || [[ -n ${adddracutargs} ]] |
920 |
then |
then |
961 |
fi |
fi |
962 |
|
|
963 |
# set this as the default if we have the package and it matches |
# set this as the default if we have the package and it matches |
964 |
if [[ ${mode} = --install ]] && [[ ${UPDATEDEFAULT} = yes ]] && [[ -n ${package} ]] && |
if [[ ${mode} = --install ]] && [[ ${UPDATEDEFAULT} = yes ]] && [[ -n ${package} ]] && [[ -n ${DEFAULTKERNEL} ]] |
|
[[ -n ${DEFAULTKERNEL} ]] && [[ ${package} = ${DEFAULTKERNEL} ]] |
|
965 |
then |
then |
966 |
makedefault="--make-default" |
if [[ ${package} = ${DEFAULTKERNEL} ]] || [[ ${package}-core = ${DEFAULTKERNEL} ]] |
967 |
[[ -n ${verbose} ]] && echo "making it the default based on config" |
then |
968 |
|
makedefault="--make-default" |
969 |
|
[[ -n ${verbose} ]] && echo "making it the default based on config" |
970 |
|
fi |
971 |
fi |
fi |
972 |
|
|
973 |
if [[ ${moddep} = make ]] |
if [[ ${moddep} = make ]] |