42 |
[ -f /etc/conf.d/grubby ] && . /etc/conf.d/grubby |
[ -f /etc/conf.d/grubby ] && . /etc/conf.d/grubby |
43 |
[ -f /etc/conf.d/grubby-uboot ] && . /etc/conf.d/grubby-uboot |
[ -f /etc/conf.d/grubby-uboot ] && . /etc/conf.d/grubby-uboot |
44 |
|
|
45 |
|
cfgGrub2="" |
46 |
|
cfgGrub2Efi="" |
47 |
cfgGrub="" |
cfgGrub="" |
48 |
cfgLilo="" |
cfgLilo="" |
49 |
cfguBoot="" |
cfguBoot="" |
98 |
# this leaves i?86 and x86_64 |
# this leaves i?86 and x86_64 |
99 |
liloConfig=/etc/lilo.conf |
liloConfig=/etc/lilo.conf |
100 |
grubConfig=/boot/grub/grub.conf |
grubConfig=/boot/grub/grub.conf |
101 |
|
grub2Config=/boot/grub/grub.cfg |
102 |
|
grub2EfiConfig=/boot/grub/grub-efi.cfg |
103 |
bootPrefix=/boot |
bootPrefix=/boot |
104 |
liloFlag=lilo |
liloFlag=lilo |
105 |
isx86="yes" |
isx86="yes" |
134 |
exit 1 |
exit 1 |
135 |
} |
} |
136 |
|
|
|
run_grub2() |
|
|
{ |
|
|
if [ -d /boot/grub -a -x /sbin/grub-mkconfig ] |
|
|
then |
|
|
cp /boot/grub/grub.cfg /boot/grub/grub.cfg.old |
|
|
/sbin/grub-mkconfig -o /boot/grub/grub.cfg |
|
|
fi |
|
|
} |
|
|
|
|
137 |
install() |
install() |
138 |
{ |
{ |
139 |
# 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) |
171 |
return |
return |
172 |
fi |
fi |
173 |
|
|
|
# Run grub2's configuration update in parallel, if it is installed |
|
|
run_grub2 |
|
|
|
|
174 |
# get the root filesystem to use |
# get the root filesystem to use |
175 |
rootdevice=$(awk '{ if ($1 !~ /^[ \t]*#/ && $2 == "/") { print $1; }}' /etc/fstab) |
rootdevice=$(awk '{ if ($1 !~ /^[ \t]*#/ && $2 == "/") { print $1; }}' /etc/fstab) |
176 |
|
|
193 |
else |
else |
194 |
title="Magellan Linux (${version})" |
title="Magellan Linux (${version})" |
195 |
fi |
fi |
196 |
${grubby} --add-kernel=${bootPrefix}/${kernelName}-${version} \ |
${grubby} --grub --add-kernel=${bootPrefix}/${kernelName}-${version} \ |
197 |
${INITRD} --copy-default ${makedefault} --title "${title}" \ |
${INITRD} --copy-default ${makedefault} --title "${title}" \ |
198 |
${mbkernel:+--add-multiboot="${mbkernel}"} ${mbargs:+--mbargs="${mbargs}"} \ |
${mbkernel:+--add-multiboot="${mbkernel}"} ${mbargs:+--mbargs="${mbargs}"} \ |
199 |
--args="root=${rootdevice} ${kernargs}" --remove-kernel="TITLE=${title}" |
--args="root=${rootdevice} ${kernargs}" --remove-kernel="TITLE=${title}" |
200 |
else |
else |
201 |
[[ -n ${verbose} ]] && echo "${grubConfig} does not exist, not running grubby" |
[[ -n ${verbose} ]] && echo "${grubConfig} does not exist, not running grubby for grub 0.97" |
202 |
|
fi |
203 |
|
if [[ -n ${cfgGrub2} ]] |
204 |
|
then |
205 |
|
[[ -n ${verbose} ]] && echo "adding ${version} to ${grub2Config}" |
206 |
|
|
207 |
|
if [[ -n ${banner} ]] |
208 |
|
then |
209 |
|
title="${banner} (${version})" |
210 |
|
elif [ -f /etc/mageversion ] |
211 |
|
then |
212 |
|
title="Magellan Linux $(< /etc/mageversion) (${version})" |
213 |
|
else |
214 |
|
title="Magellan Linux (${version})" |
215 |
|
fi |
216 |
|
${grubby} --grub2 -c ${grub2Cfg} \ |
217 |
|
--add-kernel=${bootPrefix}/${kernelName}-${version} \ |
218 |
|
${INITRD} --copy-default ${makedefault} --title "${title}" \ |
219 |
|
${mbkernel:+--add-multiboot="${mbkernel}"} \ |
220 |
|
${mbargs:+--mbargs="${mbargs}"} \ |
221 |
|
--args="root=${rootdevice} ${kernargs}" --remove-kernel="TITLE=${title}" |
222 |
|
else |
223 |
|
[[ -n ${verbose} ]] && echo "${grub2Config} does not exist, not running grubby for grub 2" |
224 |
|
fi |
225 |
|
if [[ -n ${cfgGrub2Efi} ]] |
226 |
|
then |
227 |
|
[[ -n ${verbose} ]] && echo "adding ${version} to ${grub2EfiConfig}" |
228 |
|
|
229 |
|
if [[ -n ${banner} ]] |
230 |
|
then |
231 |
|
title="${banner} (${version})" |
232 |
|
elif [ -f /etc/mageversion ] |
233 |
|
then |
234 |
|
title="Magellan Linux $(< /etc/mageversion) (${version})" |
235 |
|
else |
236 |
|
title="Magellan Linux (${version})" |
237 |
|
fi |
238 |
|
${grubby} --grub2 -c ${grub2EfiCfg} \ |
239 |
|
--add-kernel=${bootPrefix}/${kernelName}-${version} \ |
240 |
|
${INITRD} --copy-default ${makedefault} --title "${title}" \ |
241 |
|
${mbkernel:+--add-multiboot="${mbkernel}"} \ |
242 |
|
${mbargs:+--mbargs="${mbargs}"} \ |
243 |
|
--args="root=${rootdevice} ${kernargs}" --remove-kernel="TITLE=${title}" |
244 |
|
else |
245 |
|
[[ -n ${verbose} ]] && echo "${grub2EfiConfig} does not exist, not running grubby for grub 2 with UEFI" |
246 |
fi |
fi |
247 |
|
|
248 |
if [[ -n ${cfgLilo} ]] |
if [[ -n ${cfgLilo} ]] |
280 |
return |
return |
281 |
fi |
fi |
282 |
|
|
|
# Run grub2's configuration update in parallel, if it is installed |
|
|
run_grub2 |
|
|
|
|
283 |
if [[ -n ${cfgGrub} ]] |
if [[ -n ${cfgGrub} ]] |
284 |
then |
then |
285 |
[[ -n ${verbose} ]] && echo "removing ${version} from ${grubConfig}" |
[[ -n ${verbose} ]] && echo "removing ${version} from ${grubConfig}" |
286 |
${grubby} --remove-kernel=${bootPrefix}/${kernelName}-${version} |
${grubby} --grub --remove-kernel=${bootPrefix}/${kernelName}-${version} |
287 |
else |
else |
288 |
[[ -n ${verbose} ]] && echo "${grubConfig} does not exist, not running grubby" |
[[ -n ${verbose} ]] && echo "${grubConfig} does not exist, not running grubby for grub 0.97" |
289 |
|
fi |
290 |
|
if [[ -n ${cfgGrub2} ]] |
291 |
|
then |
292 |
|
[[ -n ${verbose} ]] && echo "removing ${version} from ${grub2Config}" |
293 |
|
${grubby} --grub2 -c ${grub2Config} \ |
294 |
|
--remove-kernel=${bootPrefix}/${kernelName}-${version} |
295 |
|
else |
296 |
|
[[ -n ${verbose} ]] && echo "${grub2Config} does not exist, not running grubby for grub 2" |
297 |
|
fi |
298 |
|
if [[ -n ${cfgGrub2Efi} ]] |
299 |
|
then |
300 |
|
[[ -n ${verbose} ]] && echo "removing ${version} from ${grub2EfiConfig}" |
301 |
|
${grubby} --grub2 -c ${grub2EfiConfig} \ |
302 |
|
--remove-kernel=${bootPrefix}/${kernelName}-${version} |
303 |
|
else |
304 |
|
[[ -n ${verbose} ]] && echo "${grub2EfiConfig} does not exist, not running grubby grub 2 with UEFI" |
305 |
fi |
fi |
306 |
|
|
307 |
if [[ -n ${cfgLilo} ]] |
if [[ -n ${cfgLilo} ]] |
398 |
fi |
fi |
399 |
fi |
fi |
400 |
|
|
|
# Run grub2's configuration update in parallel, if it is installed |
|
|
run_grub2 |
|
|
|
|
401 |
if [[ -n ${cfgGrub} ]] |
if [[ -n ${cfgGrub} ]] |
402 |
then |
then |
403 |
[[ -n ${verbose} ]] && echo "updating ${version} from ${grubConfig}" |
[[ -n ${verbose} ]] && echo "updating ${version} from ${grubConfig}" |
409 |
[[ -n ${verbose} ]] && echo "${grubConfig} does not exist, not running grubby" |
[[ -n ${verbose} ]] && echo "${grubConfig} does not exist, not running grubby" |
410 |
fi |
fi |
411 |
|
|
412 |
|
if [[ -n ${cfgGrub2} ]] |
413 |
|
then |
414 |
|
[[ -n ${verbose} ]] && echo "updating ${version} from ${grub2Config}" |
415 |
|
${grubby} --grub2 -c ${grub2Config} \ |
416 |
|
--update-kernel=${bootPrefix}/${kernelName}-${version} \ |
417 |
|
${INITRD} \ |
418 |
|
${kernargs:+--args="${kernargs}"} \ |
419 |
|
${removeargs:+--remove-args="${removeargs}"} |
420 |
|
else |
421 |
|
[[ -n ${verbose} ]] && echo "${grub2Config} does not exist, not running grubby" |
422 |
|
fi |
423 |
|
|
424 |
|
if [[ -n ${cfgGrub2Efi} ]] |
425 |
|
then |
426 |
|
[[ -n ${verbose} ]] && echo "updating ${version} from ${grub2EfiConfig}" |
427 |
|
${grubby} --grub2 -c ${grub2EfiConfig} \ |
428 |
|
--update-kernel=${bootPrefix}/${kernelName}-${version} \ |
429 |
|
${INITRD} \ |
430 |
|
${kernargs:+--args="${kernargs}"} \ |
431 |
|
${removeargs:+--remove-args="${removeargs}"} |
432 |
|
else |
433 |
|
[[ -n ${verbose} ]] && echo "${grub2EfiConfig} does not exist, not running grubby" |
434 |
|
fi |
435 |
|
|
436 |
if [[ -n ${cfgLilo} ]] |
if [[ -n ${cfgLilo} ]] |
437 |
then |
then |
438 |
[[ -n ${verbose} ]] && echo "updating ${version} from ${liloConfig}" |
[[ -n ${verbose} ]] && echo "updating ${version} from ${liloConfig}" |
749 |
fi |
fi |
750 |
|
|
751 |
[[ -n ${grubConfig} ]] && [ -f ${grubConfig} ] && cfgGrub=1 |
[[ -n ${grubConfig} ]] && [ -f ${grubConfig} ] && cfgGrub=1 |
752 |
|
[[ -n ${grub2Config} ]] && [ -f ${grub2Config} ] && cfgGrub2=1 |
753 |
|
[[ -n ${grub2EfiConfig} ]] && [ -f ${grub2EfiConfig} ] && cfgGrub2Efi=1 |
754 |
[[ -n ${liloConfig} ]] && [ -f ${liloConfig} ] && cfgLilo=1 |
[[ -n ${liloConfig} ]] && [ -f ${liloConfig} ] && cfgLilo=1 |
755 |
|
|
756 |
# if we have a uBoot directory, check if it is mounted. |
# if we have a uBoot directory, check if it is mounted. |