Magellan Linux

Diff of /trunk/grubby/new-kernel-pkg

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 2239 by niro, Mon Oct 21 13:28:04 2013 UTC revision 2684 by niro, Wed Jul 16 10:26:39 2014 UTC
# Line 116  elif [[ ${ARCH} =~ armv[5|7].*l ]] Line 116  elif [[ ${ARCH} =~ armv[5|7].*l ]]
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"}
# Line 170  usage() Line 171  usage()
171  install()  install()
172  {  {
173   # 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)
174   if [ ! -f ${bootPrefix}/${kernelName}-${version} ]   if [ ! -f ${kernelImage} ]
175   then   then
176   [[ -n ${verbose} ]] && echo "kernel for ${version} does not exist, not running grubby"   [[ -n ${verbose} ]] && echo "kernel for ${version} does not exist, not running grubby"
177   return   return
# Line 195  install() Line 196  install()
196   if [[ -z ${initrdfile} ]]   if [[ -z ${initrdfile} ]]
197   then   then
198   [[ -n ${verbose} ]] && echo "No initrd, just adding system map"   [[ -n ${verbose} ]] && echo "No initrd, just adding system map"
199   /sbin/addSystemMap ${bootPrefix}/System.map-${version} ${bootPrefix}/${kernelName}-${version} ${bootPrefix}/vmlinitrd-${version}   /sbin/addSystemMap ${bootPrefix}/System.map-${version} ${kernelImage} ${bootPrefix}/vmlinitrd-${version}
200   else   else
201   /sbin/addSystemMap ${bootPrefix}/System.map-${version} ${bootPrefix}/${kernelName}-${version} ${bootPrefix}/vmlinux.sm-${version}   /sbin/addSystemMap ${bootPrefix}/System.map-${version} ${kernelImage} ${bootPrefix}/vmlinux.sm-${version}
202   /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
203   rm ${bootPrefix}/vmlinux.sm-${version}   rm ${bootPrefix}/vmlinux.sm-${version}
204   fi   fi
# Line 219  install() Line 220  install()
220    
221   if [[ -n ${banner} ]]   if [[ -n ${banner} ]]
222   then   then
223   title="${banner} [ ${version} ]"   if [[ ${ARCH} = s390 ]] || [[ ${ARCH} = s390x ]]
224   elif [[ $(read_os_release id) = magellan ]]   then
225     title=$(echo ${banner} | sed 's/ /_/g')
226     else
227     title="${banner} [ ${version} ]"
228     fi
229     elif [[ ${ARCH} = s390 ]] || [[ ${ARCH} = s390x ]]
230     then
231     title=$(echo ${version} | sed 's/ /_/g')
232     elif [ -f /etc/os-release ]
233   then   then
234   title="$(read_os_release name) $(read_os_release version_id) [ ${version} ]"   title="$(read_os_release name) $(read_os_release version_id) [ ${version} ]"
235   elif [ -f /etc/mageversion ]   elif [ -f /etc/mageversion ]
# Line 235  install() Line 244  install()
244   [[ -n ${verbose} ]] && echo "adding ${version} to ${grubConfig}"   [[ -n ${verbose} ]] && echo "adding ${version} to ${grubConfig}"
245    
246   ${grubby} --grub -c ${grubConfig} \   ${grubby} --grub -c ${grubConfig} \
247   --add-kernel=${bootPrefix}/${kernelName}-${version} \   --add-kernel=${kernelImage} \
248   ${INITRD} --copy-default ${makedefault} --title "${title}" \   ${INITRD} --copy-default ${makedefault} --title "${title}" \
249   ${mbkernel:+--add-multiboot="${mbkernel}"} ${mbargs:+--mbargs="${mbargs}"} \   ${mbkernel:+--add-multiboot="${mbkernel}"} ${mbargs:+--mbargs="${mbargs}"} \
250   --args="root=${rootdevice} ${kernargs}" --remove-kernel="TITLE=${title}"   --args="root=${rootdevice} ${kernargs}" --remove-kernel="TITLE=${title}"
# Line 247  install() Line 256  install()
256   [[ -n ${verbose} ]] && echo "adding ${version} to ${grub2Config}"   [[ -n ${verbose} ]] && echo "adding ${version} to ${grub2Config}"
257    
258   ${grubby} --grub2 -c ${grub2Config} \   ${grubby} --grub2 -c ${grub2Config} \
259   --add-kernel=${bootPrefix}/${kernelName}-${version} \   --add-kernel=${kernelImage} \
260   ${INITRD} --copy-default ${makedefault} --title "${title}" \   ${INITRD} --copy-default ${makedefault} --title "${title}" \
261   ${mbkernel:+--add-multiboot="${mbkernel}"} \   ${mbkernel:+--add-multiboot="${mbkernel}"} \
262   ${mbargs:+--mbargs="${mbargs}"} \   ${mbargs:+--mbargs="${mbargs}"} \
# Line 260  install() Line 269  install()
269   [[ -n ${verbose} ]] && echo "adding ${version} to ${grub2EfiConfig}"   [[ -n ${verbose} ]] && echo "adding ${version} to ${grub2EfiConfig}"
270    
271   ${grubby} --grub2 -c ${grub2EfiConfig} --efi \   ${grubby} --grub2 -c ${grub2EfiConfig} --efi \
272   --add-kernel=${bootPrefix}/${kernelName}-${version} \   --add-kernel=${kernelImage} \
273   ${INITRD} --copy-default ${makedefault} --title "${title}" \   ${INITRD} --copy-default ${makedefault} --title "${title}" \
274   ${mbkernel:+--add-multiboot="${mbkernel}"} \   ${mbkernel:+--add-multiboot="${mbkernel}"} \
275   ${mbargs:+--mbargs="${mbargs}"} \   ${mbargs:+--mbargs="${mbargs}"} \
# Line 273  install() Line 282  install()
282   then   then
283   [[ -n ${verbose} ]] && echo "adding ${version} to ${liloConfig}"   [[ -n ${verbose} ]] && echo "adding ${version} to ${liloConfig}"
284    
285   ${grubby} --add-kernel=${bootPrefix}/${kernelName}-${version} ${INITRD} \   ${grubby} --add-kernel=${kernelImage} ${INITRD} \
286   --copy-default ${makedefault} --title ${version} \   --copy-default ${makedefault} --title "${title}" \
287   ${mbkernel:+--add-multiboot="${mbkernel}"} ${mbargs:+--mbargs="${mbargs}"} \   ${mbkernel:+--add-multiboot="${mbkernel}"} ${mbargs:+--mbargs="${mbargs}"} \
288   --args="root=${rootdevice} ${kernargs}" --remove-kernel="TITLE=${version}" \   --args="root=${rootdevice} ${kernargs}" --remove-kernel="TITLE=${version}" \
289   --${liloFlag}   --${liloFlag}
# Line 298  install() Line 307  install()
307   [[ -n ${verbose} ]] && echo "adding ${version} to ${extlinuxConfig}"   [[ -n ${verbose} ]] && echo "adding ${version} to ${extlinuxConfig}"
308    
309   ${grubby} --extlinux -c ${extlinuxConfig} \   ${grubby} --extlinux -c ${extlinuxConfig} \
310   --add-kernel=${bootPrefix}/${kernelName}-${version} \   --add-kernel=${kernelImage} \
311   ${INITRD} --copy-default ${makedefault} --title "${title}" \   ${INITRD} --copy-default ${makedefault} --title "${title}" \
312   ${mbkernel:+--add-multiboot="${mbkernel}"} ${mbargs:+--mbargs="${mbargs}"} \   ${mbkernel:+--add-multiboot="${mbkernel}"} ${mbargs:+--mbargs="${mbargs}"} \
313   --args="root=${rootdevice} ${kernargs}" --remove-kernel="TITLE=${title}"   --args="root=${rootdevice} ${kernargs}" --remove-kernel="TITLE=${title}"
# Line 313  remove() Line 322  remove()
322   if [ -d /proc/iSeries ]   if [ -d /proc/iSeries ]
323   then   then
324   [[ -n ${verbose} ]] && echo "On an iSeries, remove img file"   [[ -n ${verbose} ]] && echo "On an iSeries, remove img file"
325   rm -f ${bootPrefix}/${kernelName}-${version}.img 2>/dev/null   rm -f ${kernelImage}.img 2>/dev/null
326   return   return
327   fi   fi
328    
# Line 321  remove() Line 330  remove()
330   then   then
331   [[ -n ${verbose} ]] && echo "removing ${version} from ${grubConfig}"   [[ -n ${verbose} ]] && echo "removing ${version} from ${grubConfig}"
332   ${grubby} --grub -c ${grubConfig} \   ${grubby} --grub -c ${grubConfig} \
333   --remove-kernel=${bootPrefix}/${kernelName}-${version}   --remove-kernel=${kernelImage}
334   else   else
335   [[ -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"
336   fi   fi
# Line 329  remove() Line 338  remove()
338   then   then
339   [[ -n ${verbose} ]] && echo "removing ${version} from ${grub2Config}"   [[ -n ${verbose} ]] && echo "removing ${version} from ${grub2Config}"
340   ${grubby} --grub2 -c ${grub2Config} \   ${grubby} --grub2 -c ${grub2Config} \
341   --remove-kernel=${bootPrefix}/${kernelName}-${version}   --remove-kernel=${kernelImage}
342   else   else
343   [[ -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"
344   fi   fi
# Line 337  remove() Line 346  remove()
346   then   then
347   [[ -n ${verbose} ]] && echo "removing ${version} from ${grub2EfiConfig}"   [[ -n ${verbose} ]] && echo "removing ${version} from ${grub2EfiConfig}"
348   ${grubby} --grub2 -c ${grub2EfiConfig} --efi \   ${grubby} --grub2 -c ${grub2EfiConfig} --efi \
349   --remove-kernel=${bootPrefix}/${kernelName}-${version}   --remove-kernel=${kernelImage}
350   else   else
351   [[ -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"
352   fi   fi
# Line 345  remove() Line 354  remove()
354   if [[ -n ${cfgLilo} ]]   if [[ -n ${cfgLilo} ]]
355   then   then
356   [[ -n ${verbose} ]] && echo "removing ${version} from ${liloConfig}"   [[ -n ${verbose} ]] && echo "removing ${version} from ${liloConfig}"
357   ${grubby} --remove-kernel=${bootPrefix}/${kernelName}-${version} --${liloFlag}   ${grubby} --remove-kernel=${kernelImage} --${liloFlag}
358    
359   if [[ -n ${runLilo} ]]   if [[ -n ${runLilo} ]]
360   then   then
# Line 404  remove() Line 413  remove()
413   fi   fi
414    
415   mv ${tmpKList} ${ubootDir}/${ubootKList}   mv ${tmpKList} ${ubootDir}/${ubootKList}
416     [ -x /sbin/a-b-c ] && /sbin/a-b-c
417   else   else
418   [[ -n ${verbose} ]] && echo "uImage ${newversion} does not exist!"   [[ -n ${verbose} ]] && echo "uImage ${newversion} does not exist!"
419   [ -f ${tmpKList} ] && rm -f ${tmpKList}   [ -f ${tmpKList} ] && rm -f ${tmpKList}
# Line 419  remove() Line 429  remove()
429   then   then
430   [[ -n ${verbose} ]] && echo "removing ${version} from ${extlinuxConfig}"   [[ -n ${verbose} ]] && echo "removing ${version} from ${extlinuxConfig}"
431   ${grubby} --extlinux -c ${extlinuxConfig} \   ${grubby} --extlinux -c ${extlinuxConfig} \
432   --remove-kernel=${bootPrefix}/${kernelName}-${version}   --remove-kernel=${kernelImage}
433   else   else
434   [[ -n ${verbose} ]] && echo "${extlinuxConfig} does not exist, not running grubby for extlinux"   [[ -n ${verbose} ]] && echo "${extlinuxConfig} does not exist, not running grubby for extlinux"
435   fi   fi
# Line 427  remove() Line 437  remove()
437    
438  update()  update()
439  {  {
440   if [ ! -f ${bootPrefix}/${kernelName}-${version} ]   if [ ! -f ${kernelImage} ]
441   then   then
442   [[ -n ${verbose} ]] && echo "kernel for ${version} does not exist, not running grubby"   [[ -n ${verbose} ]] && echo "kernel for ${version} does not exist, not running grubby"
443   return   return
# Line 449  update() Line 459  update()
459   then   then
460   [[ -n ${verbose} ]] && echo "updating ${version} from ${grubConfig}"   [[ -n ${verbose} ]] && echo "updating ${version} from ${grubConfig}"
461   ${grubby} --grub -c ${grubConfig} \   ${grubby} --grub -c ${grubConfig} \
462   --update-kernel=${bootPrefix}/${kernelName}-${version} \   --update-kernel=${kernelImage} \
463   ${INITRD} \   ${INITRD} \
464   ${kernargs:+--args="${kernargs}"} \   ${kernargs:+--args="${kernargs}"} \
465   ${removeargs:+--remove-args="${removeargs}"}   ${removeargs:+--remove-args="${removeargs}"} \
466     ${mbkernel:+--add-multiboot="${mbkernel}"}
467   else   else
468   [[ -n ${verbose} ]] && echo "${grubConfig} does not exist, not running grubby"   [[ -n ${verbose} ]] && echo "${grubConfig} does not exist, not running grubby"
469   fi   fi
# Line 461  update() Line 472  update()
472   then   then
473   [[ -n ${verbose} ]] && echo "updating ${version} from ${grub2Config}"   [[ -n ${verbose} ]] && echo "updating ${version} from ${grub2Config}"
474   ${grubby} --grub2 -c ${grub2Config} \   ${grubby} --grub2 -c ${grub2Config} \
475   --update-kernel=${bootPrefix}/${kernelName}-${version} \   --update-kernel=${kernelImage} \
476   ${INITRD} \   ${INITRD} \
477   ${kernargs:+--args="${kernargs}"} \   ${kernargs:+--args="${kernargs}"} \
478   ${removeargs:+--remove-args="${removeargs}"}   ${removeargs:+--remove-args="${removeargs}"}
# Line 473  update() Line 484  update()
484   then   then
485   [[ -n ${verbose} ]] && echo "updating ${version} from ${grub2EfiConfig}"   [[ -n ${verbose} ]] && echo "updating ${version} from ${grub2EfiConfig}"
486   ${grubby} --grub2 -c ${grub2EfiConfig} --efi \   ${grubby} --grub2 -c ${grub2EfiConfig} --efi \
487   --update-kernel=${bootPrefix}/${kernelName}-${version} \   --update-kernel=${kernelImage} \
488   ${INITRD} \   ${INITRD} \
489   ${kernargs:+--args="${kernargs}"} \   ${kernargs:+--args="${kernargs}"} \
490   ${removeargs:+--remove-args="${removeargs}"}   ${removeargs:+--remove-args="${removeargs}"}
# Line 484  update() Line 495  update()
495   if [[ -n ${cfgLilo} ]]   if [[ -n ${cfgLilo} ]]
496   then   then
497   [[ -n ${verbose} ]] && echo "updating ${version} from ${liloConfig}"   [[ -n ${verbose} ]] && echo "updating ${version} from ${liloConfig}"
498   ${grubby} --update-kernel=${bootPrefix}/${kernelName}-${version} \   ${grubby} --update-kernel=${kernelImage} \
499   ${INITRD} \   ${INITRD} \
500   ${kernargs:+--args="${kernargs}"} \   ${kernargs:+--args="${kernargs}"} \
501   ${removeargs:+--remove-args="${removeargs}"} \   ${removeargs:+--remove-args="${removeargs}"} \
# Line 511  update() Line 522  update()
522   [[ -n ${verbose} ]] && echo "creating uImage-${version}"   [[ -n ${verbose} ]] && echo "creating uImage-${version}"
523   mkimage -A arm -O linux -T kernel -C none -a ${ubootAddress} \   mkimage -A arm -O linux -T kernel -C none -a ${ubootAddress} \
524   -e ${ubootAddress} -n ${version} \   -e ${ubootAddress} -n ${version} \
525   -d ${bootPrefix}/${kernelName}-${version} ${ubootDir}/uImage-${version}   -d ${kernelImage} ${ubootDir}/uImage-${version}
526    
527   [[ -n ${verbose} ]] && echo "creating uInitrd-${version}"   [[ -n ${verbose} ]] && echo "creating uInitrd-${version}"
528   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 \
# Line 530  update() Line 541  update()
541   [[ -n ${verbose} ]] && echo "copy uInitrd-${version} error, kernel not installed!" && exit   [[ -n ${verbose} ]] && echo "copy uInitrd-${version} error, kernel not installed!" && exit
542   fi   fi
543   echo ${version} >> ${ubootDir}/${ubootKList}   echo ${version} >> ${ubootDir}/${ubootKList}
544     [ -x /sbin/a-b-c ] && /sbin/a-b-c
545   else   else
546   [[ -n ${verbose} ]] && echo "cannot make ${version} the default"   [[ -n ${verbose} ]] && echo "cannot make ${version} the default"
547   fi   fi
# Line 541  update() Line 553  update()
553   then   then
554   [[ -n ${verbose} ]] && echo "updating ${version} from ${extlinuxConfig}"   [[ -n ${verbose} ]] && echo "updating ${version} from ${extlinuxConfig}"
555   ${grubby} --extlinux -c ${extlinuxConfig} \   ${grubby} --extlinux -c ${extlinuxConfig} \
556   --update-kernel=${bootPrefix}/${kernelName}-${version} \   --update-kernel=${kernelImage} \
557   ${INITRD} \   ${INITRD} \
558   ${kernargs:+--args="${kernargs}"} \   ${kernargs:+--args="${kernargs}"} \
559   ${removeargs:+--remove-args="${removeargs}"}   ${removeargs:+--remove-args="${removeargs}"}
# Line 583  doDepmod() Line 595  doDepmod()
595  doRmmoddep()  doRmmoddep()
596  {  {
597   [[ -n ${verbose} ]] && echo "removing modules.dep info for ${version}"   [[ -n ${verbose} ]] && echo "removing modules.dep info for ${version}"
598   [ -d /lib/modules/${version} ] && rm -f /lib/modules/${version}/modules.*   if [ -d /lib/modules/${version} ]
599     then
600     rm -f /lib/modules/${version}/modules.*.bin \
601     /lib/modules/${version}/modules.{alias,dep,devname,symbols,softdep}
602     fi
603  }  }
604    
605    
# Line 607  do Line 623  do
623   ;;   ;;
624    
625   --initrdfile*)   --initrdfile*)
626   if echo $1 | grep '=' >/dev/null   if [[ $1 == --initrdfile\=* ]]
627   then   then
628   initrdfile=$(echo $1 | sed 's/^--initrdfile=//')   initrdfile=${1#--initrdfile=}
629   else   else
630   initrdfile=$2   initrdfile=$2
631   shift   shift
# Line 617  do Line 633  do
633   ;;   ;;
634    
635   --kernel-args*)   --kernel-args*)
636   if echo $1 | grep '=' >/dev/null   if [[ $1 == --kernel-args\=* ]]
637   then   then
638   kernargs=$(echo $1 | sed 's/^--kernel-args=//')   kernargs=${1#--kernel-args=}
639   else   else
640   kernargs=$2   kernargs=$2
641   shift   shift
# Line 627  do Line 643  do
643   ;;   ;;
644    
645   --remove-args*)   --remove-args*)
646   if echo $1 | grep '=' >/dev/null   if [[ $1 == --remove-args\=* ]]
647   then   then
648   removeargs=$(echo $1 | sed 's/^--remove-args=//')   removeargs=${1#--remove-args=}
649   else   else
650   removeargs=$2   removeargs=$2
651   shift   shift
# Line 637  do Line 653  do
653   ;;   ;;
654    
655   --banner*)   --banner*)
656   if echo $1 | grep '=' >/dev/null   if [[ $1 == --banner\=* ]]
657   then   then
658   banner=$(echo $1 | sed 's/^--banner=//')   banner=${1#--banner=}
659   else   else
660   banner=$2   banner=$2
661   shift   shift
# Line 647  do Line 663  do
663   ;;   ;;
664    
665   --multiboot*)   --multiboot*)
666   if echo $1 |grep '=' >/dev/null   if [[ $1 == --multiboot\=* ]]
667   then   then
668   mbkernel=$(echo $1 | sed 's/^--multiboot=//')   mbkernel=${1#--multiboot=}
669   else   else
670   # can't really support having an optional second arg here   # can't really support having an optional second arg here
671   # sorry!   # sorry!
# Line 658  do Line 674  do
674   ;;   ;;
675    
676   --mbargs*)   --mbargs*)
677   if echo $1 |grep '=' >/dev/null   if [[ $1 == --mbargs\=* ]]
678   then   then
679   mbargs=$(echo $1 | sed 's/^--mbargs=//')   mbargs=${1#--mbargs=}
680   else   else
681   mbargs="$2"   mbargs="$2"
682   shift   shift
# Line 679  do Line 695  do
695   makedefault="--make-default"   makedefault="--make-default"
696   ;;   ;;
697    
698   --package)   --package*)
699   if echo $1 | grep '=' >/dev/null   if [[ $1 == --package\=* ]]
700   then   then
701   package=$(echo $1 | sed 's/^--package=//')   package=${1#--package=}
702   else   else
703   package=$2   package=$2
704   shift   shift
# Line 697  do Line 713  do
713   addplymouthinitrd=--add-plymouth-initrd   addplymouthinitrd=--add-plymouth-initrd
714   ;;   ;;
715    
716     --kernel-image*)
717     if [[ $1 == --kernel-image\=* ]]
718     then
719     kernelImage=${1#--kernel-image=}
720     else
721     kernelImage="$2"
722     shift
723     fi
724     if ! [[ -f ${kernelImage} ]]
725     then
726     echo "Can't find kernel image '${kernelImage}'" >&2
727     usage
728     exit 1
729     fi
730     ;;
731    
732   -v)   -v)
733   verbose=-v   verbose=-v
734   ;;   ;;
# Line 744  then Line 776  then
776   fi   fi
777  fi  fi
778    
779    [[ ${kernelImage} ]] || kernelImage="${bootPrefix}/${kernelName}-${version}"
780    
781  # 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
782  if [[ -z ${initrdfile} ]]  if [[ -z ${initrdfile} ]]
783  then  then

Legend:
Removed from v.2239  
changed lines
  Added in v.2684