79 |
grub2Config="" |
grub2Config="" |
80 |
grub2EfiConfig="" |
grub2EfiConfig="" |
81 |
extlinuxConfig="" |
extlinuxConfig="" |
82 |
|
ubootScript="/boot/boot.scr" |
83 |
|
|
84 |
ARCH=$(uname -m) |
ARCH=$(uname -m) |
85 |
|
|
113 |
lilo=/sbin/zipl |
lilo=/sbin/zipl |
114 |
runLilo="yes" |
runLilo="yes" |
115 |
isx86="" |
isx86="" |
116 |
elif [[ ${ARCH} = armv7l ]] || [[ ${ARCH} = armv7hl ]] || [[ ${ARCH} = armv5tel ]] |
elif [[ ${ARCH} =~ armv[5|7].*l ]] |
117 |
then |
then |
|
machine=$(grep "^Hardware" /proc/cpuinfo | sed 's/Hardware\s*:\s*//') |
|
118 |
liloConfig="" |
liloConfig="" |
119 |
bootPrefix=/boot |
bootPrefix=/boot |
120 |
ubootDir=${UBOOT_DIR:-"/boot/uboot"} |
extlinuxConfig=$(readlink -f /etc/extlinux.conf 2>/dev/null) |
121 |
|
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"} |
124 |
ubootDevice=/dev/${UBOOT_DEVICE:-"mmcblk0p1"} |
ubootDevice=/dev/${UBOOT_DEVICE:-"mmcblk0p1"} |
125 |
ubootDefaultImage=${UBOOT_UIMAGE:-"uImage"} |
ubootDefaultImage=${UBOOT_UIMAGE:-"uImage"} |
126 |
ubootDefaultInitrd=${UBOOT_UINITRD:-"uInitrd"} |
ubootDefaultInitrd=${UBOOT_UINITRD:-"uInitrd"} |
127 |
|
ubootAddress=${UBOOT_IMGADDR:-"0x00008000"} |
128 |
mounted="" |
mounted="" |
129 |
liloFlag="" |
liloFlag="" |
130 |
isx86="" |
isx86="" |
|
if [[ ${machine} == "OMAP3 Beagle Board" ]] || [[ ${machine} == "OMAP4 Panda board" ]] |
|
|
then |
|
|
ubootAddress=0x80008000 |
|
|
else |
|
|
ubootAddress=0x00008000 |
|
|
fi |
|
131 |
else |
else |
132 |
# this leaves i?86 and x86_64 |
# this leaves i?86 and x86_64 |
133 |
liloConfig=/etc/lilo.conf |
liloConfig=/etc/lilo.conf |
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>]" >&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 [[ x${devtreefile} != x ]] && [ -f "${devtreefile}" ] |
240 |
|
then |
241 |
|
[[ -n ${verbose} ]] && echo "found ${devtreefile} and using it with grubby" |
242 |
|
DEVTREE="--devtree ${devtreefile}" |
243 |
|
fi |
244 |
|
|
245 |
# 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? |
246 |
if [ -d /proc/iSeries ] |
if [ -d /proc/iSeries ] |
247 |
then |
then |
249 |
if [[ -z ${initrdfile} ]] |
if [[ -z ${initrdfile} ]] |
250 |
then |
then |
251 |
[[ -n ${verbose} ]] && echo "No initrd, just adding system map" |
[[ -n ${verbose} ]] && echo "No initrd, just adding system map" |
252 |
/sbin/addSystemMap ${bootPrefix}/System.map-${version} ${bootPrefix}/${kernelName}-${version} ${bootPrefix}/vmlinitrd-${version} |
/sbin/addSystemMap ${bootPrefix}/System.map-${version} ${kernelImage} ${bootPrefix}/vmlinitrd-${version} |
253 |
else |
else |
254 |
/sbin/addSystemMap ${bootPrefix}/System.map-${version} ${bootPrefix}/${kernelName}-${version} ${bootPrefix}/vmlinux.sm-${version} |
/sbin/addSystemMap ${bootPrefix}/System.map-${version} ${kernelImage} ${bootPrefix}/vmlinux.sm-${version} |
255 |
/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 |
256 |
rm ${bootPrefix}/vmlinux.sm-${version} |
rm ${bootPrefix}/vmlinux.sm-${version} |
257 |
fi |
fi |
259 |
fi |
fi |
260 |
|
|
261 |
# get the root filesystem to use |
# get the root filesystem to use |
262 |
rootdevice=$(awk '{ if ($1 !~ /^[ \t]*#/ && $2 == "/") { print $1; }}' /etc/fstab) |
rootdevice=$(awk '{ if ($1 !~ /^[ \t]*#/ && $2 == "/") { print $1; }}' /etc/fstab 2>/dev/null) |
263 |
|
if [[ -z $rootdevice ]] |
264 |
|
then |
265 |
|
rootdevice=$(grep -o -P "(?<=root=)\S+" /proc/cmdline) |
266 |
|
fi |
267 |
|
|
268 |
if [[ -n ${mbkernel} ]] && [[ -n ${cfgLilo} ]] && [[ ${liloFlag} != elilo ]] |
if [[ -n ${mbkernel} ]] && [[ -n ${cfgLilo} ]] && [[ ${liloFlag} != elilo ]] |
269 |
then |
then |
271 |
cfgLilo="" |
cfgLilo="" |
272 |
fi |
fi |
273 |
|
|
274 |
|
set_title |
275 |
|
|
276 |
if [[ -n ${cfgGrub} ]] |
if [[ -n ${cfgGrub} ]] |
277 |
then |
then |
278 |
[[ -n ${verbose} ]] && echo "adding ${version} to ${grubConfig}" |
[[ -n ${verbose} ]] && echo "adding ${version} to ${grubConfig}" |
279 |
|
|
280 |
if [[ -n ${banner} ]] |
ARGS="--grub -c ${grubConfig} --add-kernel=${kernelImage} ${INITRD} \ |
281 |
then |
${mbkernel:+--add-multiboot=\"${mbkernel}\"} \ |
282 |
title="${banner} [ ${version} ]" |
${mbargs:+--mbargs=\"${mbargs}\"} \ |
283 |
elif [ -f /etc/mageversion ] |
--title=\"${title}\${debugtitle}\" --copy-default \ |
284 |
then |
--args=\"root=${rootdevice} ${kernargs} \${debugargs}\" \ |
285 |
title="Magellan Linux $(< /etc/mageversion) [ ${version} ]" |
--remove-kernel=\"TITLE=${title}\${debugtitle}\"" |
286 |
elif [[ $(read_os_release id) = magellan ]] |
rungrubby --debug ${ARGS} |
287 |
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}" |
|
288 |
else |
else |
289 |
[[ -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" |
290 |
fi |
fi |
292 |
then |
then |
293 |
[[ -n ${verbose} ]] && echo "adding ${version} to ${grub2Config}" |
[[ -n ${verbose} ]] && echo "adding ${version} to ${grub2Config}" |
294 |
|
|
295 |
if [[ -n ${banner} ]] |
ARGS="--grub2 -c ${grub2Config} --add-kernel=${kernelImage} ${INITRD} \ |
296 |
then |
--copy-default --title \"${title}\${debugtitle}\" \ |
297 |
title="${banner} [ ${version} ]" |
${mbkernel:+--add-multiboot=\"${mbkernel}\"} \ |
298 |
elif [ -f /etc/mageversion ] |
${mbargs:+--mbargs=\"${mbargs}\"} \ |
299 |
then |
--args=\"root=${rootdevice} ${kernargs} \${debugargs}\" \ |
300 |
title="Magellan Linux $(< /etc/mageversion) [ ${version} ]" |
--remove-kernel=\"TITLE=${title}\${debugtitle}\"" |
301 |
elif [[ $(read_os_release id) = magellan ]] |
rungrubby --debug ${ARGS} |
302 |
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}" |
|
303 |
else |
else |
304 |
[[ -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" |
305 |
fi |
fi |
307 |
then |
then |
308 |
[[ -n ${verbose} ]] && echo "adding ${version} to ${grub2EfiConfig}" |
[[ -n ${verbose} ]] && echo "adding ${version} to ${grub2EfiConfig}" |
309 |
|
|
310 |
if [[ -n ${banner} ]] |
ARGS="--grub2 -c ${grub2EfiConfig} --efi \ |
311 |
then |
--add-kernel=${kernelImage} ${DEVTREE} ${INITRD} \ |
312 |
title="${banner} [ ${version} ]" |
--copy-default --title \"${title}\${debugtitle}\" \ |
313 |
elif [ -f /etc/mageversion ] |
${mbkernel:+--add-multiboot=\"${mbkernel}\"} \ |
314 |
then |
${mbargs:+--mbargs=\"${mbargs}\"} \ |
315 |
title="Magellan Linux $(< /etc/mageversion) [ ${version} ]" |
--args=\"root=${rootdevice} ${kernargs} \${debugargs}\" \ |
316 |
elif [[ $(read_os_release id) = magellan ]] |
--remove-kernel=\"TITLE=${title}\${debugtitle}\"" |
317 |
then |
rungrubby --debug ${ARGS} |
318 |
title="$(read_os_release name) $(read_os_release version_id) [ ${version} ]" |
rungrubby ${ARGS} ${makedefault} |
|
else |
|
|
title="Magellan Linux [ ${version} ]" |
|
|
fi |
|
|
${grubby} --grub2 -c ${grub2EfiConfig} \ |
|
|
--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}" |
|
319 |
else |
else |
320 |
[[ -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" |
321 |
fi |
fi |
324 |
then |
then |
325 |
[[ -n ${verbose} ]] && echo "adding ${version} to ${liloConfig}" |
[[ -n ${verbose} ]] && echo "adding ${version} to ${liloConfig}" |
326 |
|
|
327 |
${grubby} --add-kernel=${bootPrefix}/${kernelName}-${version} ${INITRD} \ |
ARGS="--${liloFlag} --add-kernel=${kernelImage} ${INITRD} \ |
328 |
--copy-default ${makedefault} --title ${version} \ |
--copy-default --title \"${title}\${debugtitle}\" \ |
329 |
${mbkernel:+--add-multiboot="${mbkernel}"} ${mbargs:+--mbargs="${mbargs}"} \ |
${mbkernel:+--add-multiboot=\"${mbkernel}\"} \ |
330 |
--args="root=${rootdevice} ${kernargs}" --remove-kernel="TITLE=${version}" \ |
${mbargs:+--mbargs=\"${mbargs}\"} \ |
331 |
--${liloFlag} |
--args=\"root=${rootdevice} ${kernargs} \${debugargs}\" \ |
332 |
|
--remove-kernel=\"TITLE=${version}\"" |
333 |
|
rungrubby --debug ${ARGS} |
334 |
|
rungrubby ${ARGS} ${makedefault} |
335 |
|
|
336 |
if [[ -n ${runLilo} ]] |
if [[ -n ${runLilo} ]] |
337 |
then |
then |
351 |
then |
then |
352 |
[[ -n ${verbose} ]] && echo "adding ${version} to ${extlinuxConfig}" |
[[ -n ${verbose} ]] && echo "adding ${version} to ${extlinuxConfig}" |
353 |
|
|
354 |
if [[ -n ${banner} ]] |
ARGS="--extlinux -c ${extlinuxConfig} --add-kernel=${kernelImage} \ |
355 |
then |
${DEVTREE} ${INITRD} --copy-default --title \"${title}\${debugtitle}\" \ |
356 |
title="${banner} [ ${version} ]" |
${mbkernel:+--add-multiboot=\"${mbkernel}\"} \ |
357 |
elif [ -f /etc/mageversion ] |
${mbargs:+--mbargs=\"${mbargs}\"} \ |
358 |
then |
--args=\"root=${rootdevice} ${kernargs} \${debugargs}\" \ |
359 |
title="Magellan Linux $(< /etc/mageversion) [ ${version} ]" |
--remove-kernel=\"TITLE=${title}\${debugtitle}\"" |
360 |
elif [[ $(read_os_release id) = magellan ]] |
rungrubby --debug ${ARGS} |
361 |
then |
rungrubby ${ARGS} ${makedefault} |
|
title="$(read_os_release name) $(read_os_release version_id) [ ${version} ]" |
|
|
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}" |
|
362 |
else |
else |
363 |
[[ -n ${verbose} ]] && echo "${extlinuxConfig} does not exist, not running grubby for extlinux" |
[[ -n ${verbose} ]] && echo "${extlinuxConfig} does not exist, not running grubby for extlinux" |
364 |
fi |
fi |
370 |
if [ -d /proc/iSeries ] |
if [ -d /proc/iSeries ] |
371 |
then |
then |
372 |
[[ -n ${verbose} ]] && echo "On an iSeries, remove img file" |
[[ -n ${verbose} ]] && echo "On an iSeries, remove img file" |
373 |
rm -f ${bootPrefix}/${kernelName}-${version}.img 2>/dev/null |
rm -f ${kernelImage}.img 2>/dev/null |
374 |
return |
return |
375 |
fi |
fi |
376 |
|
|
378 |
then |
then |
379 |
[[ -n ${verbose} ]] && echo "removing ${version} from ${grubConfig}" |
[[ -n ${verbose} ]] && echo "removing ${version} from ${grubConfig}" |
380 |
${grubby} --grub -c ${grubConfig} \ |
${grubby} --grub -c ${grubConfig} \ |
381 |
--remove-kernel=${bootPrefix}/${kernelName}-${version} |
--remove-kernel=${kernelImage} |
382 |
else |
else |
383 |
[[ -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" |
384 |
fi |
fi |
386 |
then |
then |
387 |
[[ -n ${verbose} ]] && echo "removing ${version} from ${grub2Config}" |
[[ -n ${verbose} ]] && echo "removing ${version} from ${grub2Config}" |
388 |
${grubby} --grub2 -c ${grub2Config} \ |
${grubby} --grub2 -c ${grub2Config} \ |
389 |
--remove-kernel=${bootPrefix}/${kernelName}-${version} |
--remove-kernel=${kernelImage} |
390 |
else |
else |
391 |
[[ -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" |
392 |
fi |
fi |
393 |
if [[ -n ${cfgGrub2Efi} ]] |
if [[ -n ${cfgGrub2Efi} ]] |
394 |
then |
then |
395 |
[[ -n ${verbose} ]] && echo "removing ${version} from ${grub2EfiConfig}" |
[[ -n ${verbose} ]] && echo "removing ${version} from ${grub2EfiConfig}" |
396 |
${grubby} --grub2 -c ${grub2EfiConfig} \ |
${grubby} --grub2 -c ${grub2EfiConfig} --efi \ |
397 |
--remove-kernel=${bootPrefix}/${kernelName}-${version} |
--remove-kernel=${kernelImage} |
398 |
else |
else |
399 |
[[ -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" |
400 |
fi |
fi |
402 |
if [[ -n ${cfgLilo} ]] |
if [[ -n ${cfgLilo} ]] |
403 |
then |
then |
404 |
[[ -n ${verbose} ]] && echo "removing ${version} from ${liloConfig}" |
[[ -n ${verbose} ]] && echo "removing ${version} from ${liloConfig}" |
405 |
${grubby} --remove-kernel=${bootPrefix}/${kernelName}-${version} --${liloFlag} |
${grubby} --remove-kernel=${kernelImage} --${liloFlag} |
406 |
|
|
407 |
if [[ -n ${runLilo} ]] |
if [[ -n ${runLilo} ]] |
408 |
then |
then |
426 |
then |
then |
427 |
tmpKList=$(mktemp ${ubootDir}/${ubootKList}.XXXX) |
tmpKList=$(mktemp ${ubootDir}/${ubootKList}.XXXX) |
428 |
curversion=$(tail -n1 ${ubootDir}/${ubootKList}) |
curversion=$(tail -n1 ${ubootDir}/${ubootKList}) |
429 |
sed "/${version}/d" ${ubootDir}/${ubootKList} > ${tmpKList} |
sed "/$version$/d" ${ubootDir}/${ubootKList} > ${tmpKList} |
430 |
newversion=$(tail -n1 ${tmpKList}) |
newversion=$(tail -n1 ${tmpKList}) |
431 |
if [ -f ${ubootDir}/uImage-${newversion} ] && [ -f ${ubootDir}/uInitrd-${newversion} ] |
if [ -f ${ubootDir}/uImage-${newversion} ] && [ -f ${ubootDir}/uInitrd-${newversion} ] |
432 |
then |
then |
461 |
fi |
fi |
462 |
|
|
463 |
mv ${tmpKList} ${ubootDir}/${ubootKList} |
mv ${tmpKList} ${ubootDir}/${ubootKList} |
464 |
|
[ -x /sbin/a-b-c ] && /sbin/a-b-c |
465 |
else |
else |
466 |
[[ -n ${verbose} ]] && echo "uImage ${newversion} does not exist!" |
[[ -n ${verbose} ]] && echo "uImage ${newversion} does not exist!" |
467 |
[ -f ${tmpKList} ] && rm -f ${tmpKList} |
[ -f ${tmpKList} ] && rm -f ${tmpKList} |
477 |
then |
then |
478 |
[[ -n ${verbose} ]] && echo "removing ${version} from ${extlinuxConfig}" |
[[ -n ${verbose} ]] && echo "removing ${version} from ${extlinuxConfig}" |
479 |
${grubby} --extlinux -c ${extlinuxConfig} \ |
${grubby} --extlinux -c ${extlinuxConfig} \ |
480 |
--remove-kernel=${bootPrefix}/${kernelName}-${version} |
--remove-kernel=${kernelImage} |
481 |
else |
else |
482 |
[[ -n ${verbose} ]] && echo "${extlinuxConfig} does not exist, not running grubby for extlinux" |
[[ -n ${verbose} ]] && echo "${extlinuxConfig} does not exist, not running grubby for extlinux" |
483 |
fi |
fi |
485 |
|
|
486 |
update() |
update() |
487 |
{ |
{ |
488 |
if [ ! -f ${bootPrefix}/${kernelName}-${version} ] |
if [ ! -f ${kernelImage} ] |
489 |
then |
then |
490 |
[[ -n ${verbose} ]] && echo "kernel for ${version} does not exist, not running grubby" |
[[ -n ${verbose} ]] && echo "kernel for ${version} does not exist, not running grubby" |
491 |
return |
return |
492 |
fi |
fi |
493 |
|
|
494 |
|
set_title |
495 |
|
|
496 |
INITRD="" |
INITRD="" |
497 |
if [ -f ${initrdfile} ] |
if [ -f ${initrdfile} ] |
498 |
then |
then |
505 |
fi |
fi |
506 |
fi |
fi |
507 |
|
|
508 |
|
DEVTREE="" |
509 |
|
if [[ x${devtreefile} != x ]] && [ -f ${devtreefile} ] |
510 |
|
then |
511 |
|
[[ -n ${verbose} ]] && echo "found ${devtreefile} and using it with grubby" |
512 |
|
DEVTREE="--devtree ${devtreefile}" |
513 |
|
fi |
514 |
|
|
515 |
if [[ -n ${cfgGrub} ]] |
if [[ -n ${cfgGrub} ]] |
516 |
then |
then |
517 |
[[ -n ${verbose} ]] && echo "updating ${version} from ${grubConfig}" |
[[ -n ${verbose} ]] && echo "updating ${version} from ${grubConfig}" |
518 |
${grubby} --grub -c ${grubConfig} \ |
ARGS="--grub -c ${grubConfig} --update-kernel=${kernelImage} ${INITRD} \ |
519 |
--update-kernel=${bootPrefix}/${kernelName}-${version} \ |
${kernargs:+--args=\"${kernargs}\"} \ |
520 |
${INITRD} \ |
${removeargs:+--remove-args=\"${removeargs}\"} \ |
521 |
${kernargs:+--args="${kernargs}"} \ |
${mbkernel:+--add-multiboot=\"${mbkernel}\"} \ |
522 |
${removeargs:+--remove-args="${removeargs}"} |
--title=\"${title}\${debugtitle}\"" |
523 |
|
rungrubby --debug ${ARGS} |
524 |
|
rungrubby ${ARGS} |
525 |
else |
else |
526 |
[[ -n ${verbose} ]] && echo "${grubConfig} does not exist, not running grubby" |
[[ -n ${verbose} ]] && echo "${grubConfig} does not exist, not running grubby" |
527 |
fi |
fi |
529 |
if [[ -n ${cfgGrub2} ]] |
if [[ -n ${cfgGrub2} ]] |
530 |
then |
then |
531 |
[[ -n ${verbose} ]] && echo "updating ${version} from ${grub2Config}" |
[[ -n ${verbose} ]] && echo "updating ${version} from ${grub2Config}" |
532 |
${grubby} --grub2 -c ${grub2Config} \ |
ARGS="--grub2 -c ${grub2Config} --update-kernel=${kernelImage} ${INITRD} \ |
533 |
--update-kernel=${bootPrefix}/${kernelName}-${version} \ |
${kernargs:+--args=\"${kernargs}\"} \ |
534 |
${INITRD} \ |
${removeargs:+--remove-args=\"${removeargs}\"} \ |
535 |
${kernargs:+--args="${kernargs}"} \ |
--title=\"${title}\${debugtitle}\"" |
536 |
${removeargs:+--remove-args="${removeargs}"} |
rungrubby --debug ${ARGS} |
537 |
|
rungrubby ${ARGS} |
538 |
else |
else |
539 |
[[ -n ${verbose} ]] && echo "${grub2Config} does not exist, not running grubby" |
[[ -n ${verbose} ]] && echo "${grub2Config} does not exist, not running grubby" |
540 |
fi |
fi |
542 |
if [[ -n ${cfgGrub2Efi} ]] |
if [[ -n ${cfgGrub2Efi} ]] |
543 |
then |
then |
544 |
[[ -n ${verbose} ]] && echo "updating ${version} from ${grub2EfiConfig}" |
[[ -n ${verbose} ]] && echo "updating ${version} from ${grub2EfiConfig}" |
545 |
${grubby} --grub2 -c ${grub2EfiConfig} \ |
ARGS="--grub2 -c ${grub2EfiConfig} --efi --update-kernel=${kernelImage} \ |
546 |
--update-kernel=${bootPrefix}/${kernelName}-${version} \ |
${INITRD} ${kernargs:+--args=\"${kernargs}\"} \ |
547 |
${INITRD} \ |
${removeargs:+--remove-args=\"${removeargs}\"} \ |
548 |
${kernargs:+--args="${kernargs}"} \ |
--title=\"${title}\${debugtitle}\"" |
549 |
${removeargs:+--remove-args="${removeargs}"} |
rungrubby --debug ${ARGS} |
550 |
|
rungrubby ${ARGS} |
551 |
else |
else |
552 |
[[ -n ${verbose} ]] && echo "${grub2EfiConfig} does not exist, not running grubby" |
[[ -n ${verbose} ]] && echo "${grub2EfiConfig} does not exist, not running grubby" |
553 |
fi |
fi |
555 |
if [[ -n ${cfgLilo} ]] |
if [[ -n ${cfgLilo} ]] |
556 |
then |
then |
557 |
[[ -n ${verbose} ]] && echo "updating ${version} from ${liloConfig}" |
[[ -n ${verbose} ]] && echo "updating ${version} from ${liloConfig}" |
558 |
${grubby} --update-kernel=${bootPrefix}/${kernelName}-${version} \ |
ARGS="--${liloFlag} --update-kernel=${kernelImage} ${INITRD} \ |
559 |
${INITRD} \ |
${kernargs:+--args=\"${kernargs}\"} \ |
560 |
${kernargs:+--args="${kernargs}"} \ |
${removeargs:+--remove-args=\"${removeargs}\"} \ |
561 |
${removeargs:+--remove-args="${removeargs}"} \ |
--title=\"${title}\${debugtitle}\"" |
562 |
--${liloFlag} |
rungrubby --debug ${ARGS} |
563 |
|
rungrubby ${ARGS} |
564 |
|
|
565 |
if [[ -n ${runLilo} ]] |
if [[ -n ${runLilo} ]] |
566 |
then |
then |
583 |
[[ -n ${verbose} ]] && echo "creating uImage-${version}" |
[[ -n ${verbose} ]] && echo "creating uImage-${version}" |
584 |
mkimage -A arm -O linux -T kernel -C none -a ${ubootAddress} \ |
mkimage -A arm -O linux -T kernel -C none -a ${ubootAddress} \ |
585 |
-e ${ubootAddress} -n ${version} \ |
-e ${ubootAddress} -n ${version} \ |
586 |
-d ${bootPrefix}/${kernelName}-${version} ${ubootDir}/uImage-${version} |
-d ${kernelImage} ${ubootDir}/uImage-${version} |
587 |
|
|
588 |
[[ -n ${verbose} ]] && echo "creating uInitrd-${version}" |
[[ -n ${verbose} ]] && echo "creating uInitrd-${version}" |
589 |
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 \ |
602 |
[[ -n ${verbose} ]] && echo "copy uInitrd-${version} error, kernel not installed!" && exit |
[[ -n ${verbose} ]] && echo "copy uInitrd-${version} error, kernel not installed!" && exit |
603 |
fi |
fi |
604 |
echo ${version} >> ${ubootDir}/${ubootKList} |
echo ${version} >> ${ubootDir}/${ubootKList} |
605 |
|
[ -x /sbin/a-b-c ] && /sbin/a-b-c |
606 |
else |
else |
607 |
[[ -n ${verbose} ]] && echo "cannot make ${version} the default" |
[[ -n ${verbose} ]] && echo "cannot make ${version} the default" |
608 |
fi |
fi |
613 |
if [[ -n ${cfgExtlinux} ]] |
if [[ -n ${cfgExtlinux} ]] |
614 |
then |
then |
615 |
[[ -n ${verbose} ]] && echo "updating ${version} from ${extlinuxConfig}" |
[[ -n ${verbose} ]] && echo "updating ${version} from ${extlinuxConfig}" |
616 |
${grubby} --extlinux -c ${extlinuxConfig} \ |
ARGS="--extlinux -c ${extlinuxConfig} --update-kernel=${kernelImage} \ |
617 |
--update-kernel=${bootPrefix}/${kernelName}-${version} \ |
${DEVTREE} ${INITRD} ${kernargs:+--args=\"${kernargs}\"} \ |
618 |
${INITRD} \ |
${removeargs:+--remove-args=\"${removeargs}\"} \ |
619 |
${kernargs:+--args="${kernargs}"} \ |
--title=\"${title}\${debugtitle}\"" |
620 |
${removeargs:+--remove-args="${removeargs}"} |
rungrubby --debug ${ARGS} |
621 |
|
rungrubby ${ARGS} |
622 |
else |
else |
623 |
[[ -n ${verbose} ]] && echo "${extlinuxConfig} does not exist, not running grubby" |
[[ -n ${verbose} ]] && echo "${extlinuxConfig} does not exist, not running grubby" |
624 |
fi |
fi |
657 |
doRmmoddep() |
doRmmoddep() |
658 |
{ |
{ |
659 |
[[ -n ${verbose} ]] && echo "removing modules.dep info for ${version}" |
[[ -n ${verbose} ]] && echo "removing modules.dep info for ${version}" |
660 |
[ -d /lib/modules/${version} ] && rm -f /lib/modules/${version}/modules.* |
if [ -d /lib/modules/${version} ] |
661 |
|
then |
662 |
|
rm -f /lib/modules/${version}/modules.*.bin \ |
663 |
|
/lib/modules/${version}/modules.{alias,dep,devname,symbols,softdep} |
664 |
|
fi |
665 |
} |
} |
666 |
|
|
667 |
|
# kernel image for 2.4 is kernel |
668 |
|
if [[ ${ARCH} = ppc64 ]] || [[ ${ARCH} = ppc ]] |
669 |
|
then |
670 |
|
if [[ ${kernelmajor} = 2.4 ]] |
671 |
|
then |
672 |
|
kernelName=kernel |
673 |
|
fi |
674 |
|
fi |
675 |
|
|
676 |
while [ $# -gt 0 ] |
while [ $# -gt 0 ] |
677 |
do |
do |
684 |
initrd="remove" |
initrd="remove" |
685 |
;; |
;; |
686 |
|
|
687 |
|
--devtree*) |
688 |
|
if [[ $1 == --devtree\=* ]] |
689 |
|
then |
690 |
|
devtreefile="${1#--devtreefile=}" |
691 |
|
else |
692 |
|
devtreefile="$2" |
693 |
|
shift |
694 |
|
fi |
695 |
|
;; |
696 |
|
|
697 |
--dracut) |
--dracut) |
698 |
dracut=--dracut |
dracut=--dracut |
699 |
;; |
;; |
703 |
;; |
;; |
704 |
|
|
705 |
--initrdfile*) |
--initrdfile*) |
706 |
if echo $1 | grep '=' >/dev/null |
if [[ $1 == --initrdfile\=* ]] |
707 |
then |
then |
708 |
initrdfile=$(echo $1 | sed 's/^--initrdfile=//') |
initrdfile=${1#--initrdfile=} |
709 |
else |
else |
710 |
initrdfile=$2 |
initrdfile=$2 |
711 |
shift |
shift |
713 |
;; |
;; |
714 |
|
|
715 |
--kernel-args*) |
--kernel-args*) |
716 |
if echo $1 | grep '=' >/dev/null |
if [[ $1 == --kernel-args\=* ]] |
717 |
then |
then |
718 |
kernargs=$(echo $1 | sed 's/^--kernel-args=//') |
kernargs=${1#--kernel-args=} |
719 |
else |
else |
720 |
kernargs=$2 |
kernargs=$2 |
721 |
shift |
shift |
723 |
;; |
;; |
724 |
|
|
725 |
--remove-args*) |
--remove-args*) |
726 |
if echo $1 | grep '=' >/dev/null |
if [[ $1 == --remove-args\=* ]] |
727 |
then |
then |
728 |
removeargs=$(echo $1 | sed 's/^--remove-args=//') |
removeargs=${1#--remove-args=} |
729 |
else |
else |
730 |
removeargs=$2 |
removeargs=$2 |
731 |
shift |
shift |
733 |
;; |
;; |
734 |
|
|
735 |
--banner*) |
--banner*) |
736 |
if echo $1 | grep '=' >/dev/null |
if [[ $1 == --banner\=* ]] |
737 |
then |
then |
738 |
banner=$(echo $1 | sed 's/^--banner=//') |
banner=${1#--banner=} |
739 |
else |
else |
740 |
banner=$2 |
banner=$2 |
741 |
shift |
shift |
743 |
;; |
;; |
744 |
|
|
745 |
--multiboot*) |
--multiboot*) |
746 |
if echo $1 |grep '=' >/dev/null |
if [[ $1 == --multiboot\=* ]] |
747 |
then |
then |
748 |
mbkernel=$(echo $1 | sed 's/^--multiboot=//') |
mbkernel=${1#--multiboot=} |
749 |
else |
else |
750 |
# can't really support having an optional second arg here |
# can't really support having an optional second arg here |
751 |
# sorry! |
# sorry! |
754 |
;; |
;; |
755 |
|
|
756 |
--mbargs*) |
--mbargs*) |
757 |
if echo $1 |grep '=' >/dev/null |
if [[ $1 == --mbargs\=* ]] |
758 |
then |
then |
759 |
mbargs=$(echo $1 | sed 's/^--mbargs=//') |
mbargs=${1#--mbargs=} |
760 |
else |
else |
761 |
mbargs="$2" |
mbargs="$2" |
762 |
shift |
shift |
775 |
makedefault="--make-default" |
makedefault="--make-default" |
776 |
;; |
;; |
777 |
|
|
778 |
--package) |
--package*) |
779 |
if echo $1 | grep '=' >/dev/null |
if [[ $1 == --package\=* ]] |
780 |
then |
then |
781 |
package=$(echo $1 | sed 's/^--package=//') |
package=${1#--package=} |
782 |
else |
else |
783 |
package=$2 |
package=$2 |
784 |
shift |
shift |
793 |
addplymouthinitrd=--add-plymouth-initrd |
addplymouthinitrd=--add-plymouth-initrd |
794 |
;; |
;; |
795 |
|
|
796 |
|
--kernel-image*) |
797 |
|
if [[ $1 == --kernel-image\=* ]] |
798 |
|
then |
799 |
|
kernelImage=${1#--kernel-image=} |
800 |
|
else |
801 |
|
kernelImage="$2" |
802 |
|
shift |
803 |
|
fi |
804 |
|
if ! [[ -f ${kernelImage} ]] |
805 |
|
then |
806 |
|
echo "Can't find kernel image '${kernelImage}'" >&2 |
807 |
|
usage |
808 |
|
exit 1 |
809 |
|
fi |
810 |
|
;; |
811 |
|
|
812 |
|
--kernel-name*) |
813 |
|
if [[ $1 == --kernel-name\=* ]] |
814 |
|
then |
815 |
|
kernelName=${1#--kernel-name=} |
816 |
|
else |
817 |
|
kernelName="$2" |
818 |
|
shift |
819 |
|
fi |
820 |
|
;; |
821 |
|
|
822 |
-v) |
-v) |
823 |
verbose=-v |
verbose=-v |
824 |
;; |
;; |
857 |
|
|
858 |
kernelmajor=$(echo ${kernel} | cut -d . -f 1,2) |
kernelmajor=$(echo ${kernel} | cut -d . -f 1,2) |
859 |
|
|
860 |
# 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 |
|
861 |
|
|
862 |
# 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 |
863 |
if [[ -z ${initrdfile} ]] |
if [[ -z ${initrdfile} ]] |
877 |
fi |
fi |
878 |
[[ -n ${verbose} ]] && echo "initrdfile is ${initrdfile}" |
[[ -n ${verbose} ]] && echo "initrdfile is ${initrdfile}" |
879 |
|
|
880 |
|
if [[ ${ARCH} =~ armv[5|7].*l ]] |
881 |
|
then |
882 |
|
if [ -d ${bootPrefix}/dtb-${version}/ ] |
883 |
|
then |
884 |
|
devtreedir="${bootPrefix}/dtb-${version}/" |
885 |
|
if [[ -n ${dtbfile} ]] && [ -f ${devtreedir}/${dtbfile} ] |
886 |
|
then |
887 |
|
devtreefile="${devtreedir}/${dtbfile}" |
888 |
|
fi |
889 |
|
fi |
890 |
|
fi |
891 |
|
[[ -n ${verbose} ]] && echo "devtreedir is ${devtreedir}" |
892 |
|
|
893 |
# add dracut i18n, keyboard and plymouth kernel args if requested |
# add dracut i18n, keyboard and plymouth kernel args if requested |
894 |
if [[ -n ${dracut} ]] || [[ -n ${adddracutargs} ]] |
if [[ -n ${dracut} ]] || [[ -n ${adddracutargs} ]] |
895 |
then |
then |
896 |
[ -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} ]] |
|
897 |
then |
then |
898 |
kernargs="${kernargs} KEYTABLE=${KEYMAP}" |
. /etc/vconsole.conf |
899 |
|
|
900 |
|
for i in SYSFONT SYSFONTACM UNIMAP KEYTABLE |
901 |
|
do |
902 |
|
val=$(eval echo \$$i) |
903 |
|
[[ -n ${val} ]] && kernargs="${kernargs} ${i}=${val}" |
904 |
|
done |
905 |
|
else |
906 |
|
if [ -r /etc/conf.d/consolefont ] |
907 |
|
then |
908 |
|
. /etc/conf.d/consolefont |
909 |
|
|
910 |
|
if [[ -n ${CONSOLEFONT} ]] |
911 |
|
then |
912 |
|
kernargs="${kernargs} SYSFONT=${CONSOLEFONT}" |
913 |
|
fi |
914 |
|
fi |
915 |
|
|
916 |
|
if [ -r /etc/conf.d/keymap ] |
917 |
|
then |
918 |
|
. /etc/conf.d/keymap |
919 |
|
|
920 |
|
if [[ -n ${KEYMAP} ]] |
921 |
|
then |
922 |
|
kernargs="${kernargs} KEYTABLE=${KEYMAP}" |
923 |
|
fi |
924 |
|
fi |
925 |
fi |
fi |
926 |
|
|
927 |
if [[ -n ${CONSOLEFONT} ]] |
if [ -r /etc/locale.conf ] |
928 |
then |
then |
929 |
kernargs="${kernargs} SYSFONT=${CONSOLEFONT}" |
. /etc/locale.conf |
930 |
|
|
931 |
|
if [[ -n ${LANG} ]] |
932 |
|
then |
933 |
|
kernargs="${kernargs} LANG=${LANG}" |
934 |
|
fi |
935 |
fi |
fi |
936 |
fi |
fi |
937 |
|
|
938 |
# 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 |
939 |
if [[ ${mode} = --install ]] && [[ ${UPDATEDEFAULT} = yes ]] && [[ -n ${package} ]] && |
if [[ ${mode} = --install ]] && [[ ${UPDATEDEFAULT} = yes ]] && [[ -n ${package} ]] && [[ -n ${DEFAULTKERNEL} ]] |
|
[[ -n ${DEFAULTKERNEL} ]] && [[ ${package} = ${DEFAULTKERNEL} ]] |
|
940 |
then |
then |
941 |
makedefault="--make-default" |
if [[ ${package} = ${DEFAULTKERNEL} ]] || [[ ${package}-core = ${DEFAULTKERNEL} ]] |
942 |
[[ -n ${verbose} ]] && echo "making it the default based on config" |
then |
943 |
|
makedefault="--make-default" |
944 |
|
[[ -n ${verbose} ]] && echo "making it the default based on config" |
945 |
|
fi |
946 |
fi |
fi |
947 |
|
|
948 |
if [[ ${moddep} = make ]] |
if [[ ${moddep} = make ]] |
991 |
fi |
fi |
992 |
fi |
fi |
993 |
|
|
994 |
|
# if we're using U-Boot, check if the default load address should change |
995 |
|
if [[ -n ${cfguBoot} ]] && [[ -z ${UBOOT_IMGADDR} ]] |
996 |
|
then |
997 |
|
[[ ${version} =~ .([^.]*)$ ]] |
998 |
|
platform=${BASH_REMATCH[1]} |
999 |
|
# A few platforms use an alternate kernel load address |
1000 |
|
if [[ ${platform} = omap ]] |
1001 |
|
then |
1002 |
|
ubootAddress=0x80008000 |
1003 |
|
elif [[ ${platform} = imx ]] |
1004 |
|
then |
1005 |
|
ubootAddress=0x90008000 |
1006 |
|
fi |
1007 |
|
fi |
1008 |
|
|
1009 |
# if we have a lilo config on an x86 box, see if the default boot loader |
# if we have a lilo config on an x86 box, see if the default boot loader |
1010 |
# is lilo to determine if it should be run |
# is lilo to determine if it should be run |
1011 |
if [[ -n ${cfgLilo} ]] && [[ -n ${isx86} ]] |
if [[ -n ${cfgLilo} ]] && [[ -n ${isx86} ]] |