Magellan Linux

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

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

revision 923 by niro, Wed Oct 28 12:02:45 2009 UTC revision 924 by niro, Wed Oct 28 13:26:45 2009 UTC
# Line 1  Line 1 
1  #!/bin/bash  #!/bin/bash
2    # $Id$
3  #  #
4  # new-kernel-pkg  # new-kernel-pkg
5  # Invoked upon installation or removal of a kernel package, the following  # Invoked upon installation or removal of a kernel package, the following
# Line 31  lilo=/sbin/lilo Line 32  lilo=/sbin/lilo
32  # some defaults that are sane for most arches  # some defaults that are sane for most arches
33  kernelName=kernel  kernelName=kernel
34    
35  if [ -x ./grubby ]; then  if [ -x ./grubby ]
36      grubby=./grubby  then
37     grubby=./grubby
38  else  else
39      grubby=/sbin/grubby   grubby=/sbin/grubby
40  fi  fi
41    
42  [ -f /etc/sysconfig/kernel ] && . /etc/sysconfig/kernel  [ -f /etc/sysconfig/kernel ] && . /etc/sysconfig/kernel
# Line 46  grubConfig="" Line 48  grubConfig=""
48    
49  ARCH=$(uname -m)  ARCH=$(uname -m)
50    
51  if [ $ARCH = 'ia64' ]; then  if [[ ${ARCH} = ia64 ]]
52      liloConfig=/boot/efi/EFI/redhat/elilo.conf  then
53      bootPrefix=/boot/efi/EFI/redhat   liloConfig=/boot/efi/EFI/redhat/elilo.conf
54      liloFlag=elilo   bootPrefix=/boot/efi/EFI/redhat
55      isx86=""   liloFlag=elilo
56  elif [ $ARCH = 'ppc64' -o $ARCH = 'ppc' ]; then   isx86=""
57      liloConfig=/etc/yaboot.conf  elif [[ ${ARCH} = ppc64 ]] || [[ ${ARCH} = ppc ]]
58      bootPrefix=/boot  then
59      lilo=/sbin/ybin   liloConfig=/etc/yaboot.conf
60      liloFlag=yaboot   bootPrefix=/boot
61      runLilo="yes"   lilo=/sbin/ybin
62      isx86=""   liloFlag=yaboot
63  elif [ $ARCH = 'sparc' -o $ARCH = 'sparc64' ]; then   runLilo="yes"
64      liloConfig=/etc/silo.conf   isx86=""
65      bootPrefix=/boot  elif [[ ${ARCH} = sparc ]] || [[ ${ARCH} = sparc64 ]]
66      liloFlag=silo  then
67      lilo=/sbin/silo   liloConfig=/etc/silo.conf
68      isx86=""   bootPrefix=/boot
69  elif [ $ARCH = 's390' -o $ARCH = 's390x' ]; then   liloFlag=silo
70      liloConfig=/etc/zipl.conf   lilo=/sbin/silo
71      bootPrefix=/boot   isx86=""
72      liloFlag=zipl  elif [[ ${ARCH} = s390 ]] || [[ ${ARCH} = s390x ]]
73      lilo=/sbin/zipl  then
74      runLilo="yes"   liloConfig=/etc/zipl.conf
75      isx86=""   bootPrefix=/boot
76     liloFlag=zipl
77     lilo=/sbin/zipl
78     runLilo="yes"
79     isx86=""
80  else  else
81      # this leaves i?86 and x86_64   # this leaves i?86 and x86_64
82      liloConfig=/etc/lilo.conf   liloConfig=/etc/lilo.conf
83      grubConfig=/boot/grub/grub.conf   grubConfig=/boot/grub/grub.conf
84      bootPrefix=/boot   bootPrefix=/boot
85      liloFlag=lilo   liloFlag=lilo
86      isx86="yes"   isx86="yes"
87  fi  fi
88    
89  mode=""  mode=""
# Line 91  package="" Line 97  package=""
97  mbkernel=""  mbkernel=""
98  mbargs=""  mbargs=""
99    
100  usage() {  usage()
101      echo "Usage: `basename $0` [-v] [--mkinitrd] [--rminitrd]" >&2  {
102      echo "       [--initrdfile=<initrd-image>] [--depmod] [--rmmoddep]" >&2   echo "Usage: $(basename $0) [-v] [--mkinitrd] [--rminitrd]" >&2
103      echo "       [--kernel-args=<args>] [--remove-args=<args>]" >&2   echo "       [--initrdfile=<initrd-image>] [--depmod] [--rmmoddep]" >&2
104      echo "       [--banner=<banner>] [--multiboot=multiboot]" >&2   echo "       [--kernel-args=<args>] [--remove-args=<args>]" >&2
105      echo "       [--mbargs=mbargs] [--make-default]" >&2   echo "       [--banner=<banner>] [--multiboot=multiboot]" >&2
106      echo "       <--install | --remove | --update> <kernel-version>" >&2   echo "       [--mbargs=mbargs] [--make-default]" >&2
107      echo "       (ex: `basename $0` --mkinitrd --depmod --install 2.4.7-2)" >&2   echo "       <--install | --remove | --update> <kernel-version>" >&2
108      exit 1   echo "       (ex: $(basename $0) --mkinitrd --depmod --install 2.4.7-2)" >&2
109     exit 1
110  }  }
111    
112  install() {  install()
113      # XXX kernel should be able to be specified also (or work right on ia64)  {
114      if [ ! -f $bootPrefix/$kernelName-$version ] ; then   # XXX kernel should be able to be specified also (or work right on ia64)
115   [ -n "$verbose" ] && echo "kernel for $version does not exist, not running grubby"   if [ ! -f ${bootPrefix}/${kernelName}-${version} ]
116   return   then
117      fi   [[ -n ${verbose} ]] && echo "kernel for ${version} does not exist, not running grubby"
118     return
119      INITRD=""   fi
120      if [ -f $initrdfile ]; then  
121   [ -n "$verbose" ] && echo "found $initrdfile and using it with grubby"   INITRD=""
122   INITRD="--initrd $initrdfile"   if [ -f ${initrdfile} ]
123      fi   then
124     [[ -n ${verbose} ]] && echo "found ${initrdfile} and using it with grubby"
125      # FIXME: is this a good heuristic to find out if we're on iSeries?   INITRD="--initrd ${initrdfile}"
126      if [ -d /proc/iSeries ]; then   fi
127   [ -n "$verbose" ] && echo "On an iSeries, just making img file"  
128   if [ -z $initrdfile  ]; then   # FIXME: is this a good heuristic to find out if we're on iSeries?
129      [ -n "$verbose" ] && echo "No initrd, just adding system map"   if [ -d /proc/iSeries ]
130      /sbin/addSystemMap $bootPrefix/System.map-$version $bootPrefix/$kernelName-$version $bootPrefix/vmlinitrd-$version   then
131   else   [[ -n ${verbose} ]] && echo "On an iSeries, just making img file"
132      /sbin/addSystemMap $bootPrefix/System.map-$version $bootPrefix/$kernelName-$version $bootPrefix/vmlinux.sm-$version   if [[ -z ${initrdfile} ]]
133      /sbin/addRamDisk $initrdfile $bootPrefix/System.map-$version $bootPrefix/vmlinux.sm-$version $bootPrefix/vmlinitrd-$version 2>/dev/null   then
134      rm $bootPrefix/vmlinux.sm-$version   [[ -n ${verbose} ]] && echo "No initrd, just adding system map"
135   fi   /sbin/addSystemMap ${bootPrefix}/System.map-${version} ${bootPrefix}/${kernelName}-${version} ${bootPrefix}/vmlinitrd-${version}
136   return   else
137      fi   /sbin/addSystemMap ${bootPrefix}/System.map-${version} ${bootPrefix}/${kernelName}-${version} ${bootPrefix}/vmlinux.sm-${version}
138     /sbin/addRamDisk ${initrdfile} ${bootPrefix}/System.map-${version} ${bootPrefix}/vmlinux.sm-${version} ${bootPrefix}/vmlinitrd-${version} 2>/dev/null
139      # get the root filesystem to use   rm ${bootPrefix}/vmlinux.sm-${version}
140      rootdevice=$(awk '{ if ($1 !~ /^[ \t]*#/ && $2 == "/") { print $1; }}' /etc/fstab)   fi
141     return
142      if [ -n "$mbkernel" -a -n "$cfgLilo" -a "$liloFlag" != "elilo" ]; then   fi
143   [ -n "$verbose" ] && echo "multiboot specified, not updating lilo.conf"  
144   cfgLilo=""   # get the root filesystem to use
145      fi   rootdevice=$(awk '{ if ($1 !~ /^[ \t]*#/ && $2 == "/") { print $1; }}' /etc/fstab)
146    
147      if [ -n "$cfgGrub" ]; then   if [[ -n ${mbkernel} ]] && [[ -n ${cfgLilo} ]] && [[ ${liloFlag} != elilo ]]
148   [ -n "$verbose" ] && echo "adding $version to $grubConfig"   then
149     [[ -n ${verbose} ]] && echo "multiboot specified, not updating lilo.conf"
150   if [ -n "$banner" ]; then   cfgLilo=""
151              title="$banner ($version)"   fi
152   elif [ -f /etc/mageversion ]; then  
153       title="Magellan Linux $(< /etc/mageversion) ($version)"   if [[ -n ${cfgGrub} ]]
154     then
155     [[ -n ${verbose} ]] && echo "adding ${version} to ${grubConfig}"
156    
157     if [[ -n ${banner} ]]
158     then
159     title="${banner} (${version})"
160     elif [ -f /etc/mageversion ]
161     then
162     title="Magellan Linux $(< /etc/mageversion) (${version})"
163     else
164     title="Magellan Linux (${version})"
165     fi
166     ${grubby} --add-kernel=${bootPrefix}/${kernelName}-${version} \
167     ${INITRD} --copy-default ${makedefault} --title "${title}" \
168     ${mbkernel:+--add-multiboot="${mbkernel}"} ${mbargs:+--mbargs="${mbargs}"} \
169     --args="root=${rootdevice} ${kernargs}" --remove-kernel="TITLE=${title}"
170   else   else
171      title="Magellan Linux ($version)"   [[ -n ${verbose} ]] && echo "${grubConfig} does not exist, not running grubby"
172   fi   fi
  $grubby --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"  
     else  
  [ -n "$verbose" ] && echo "$grubConfig does not exist, not running grubby"  
     fi  
   
     if [ -n "$cfgLilo" ]; then  
  [ -n "$verbose" ] && echo "adding $version to $liloConfig"  
   
  $grubby --add-kernel=$bootPrefix/$kernelName-$version $INITRD \  
  --copy-default $makedefault --title $version \  
  ${mbkernel:+--add-multiboot="$mbkernel"} ${mbargs:+--mbargs="$mbargs"} \  
  --args="root=$rootdevice $kernargs" --remove-kernel="TITLE=$version" \  
  --$liloFlag  
   
  if [ -n "$runLilo" ]; then  
     [ -n "$verbose" ] && echo "running $lilo"  
     if [ ! -x $lilo ] ; then  
  [ -n "$verbose" ] && echo "$lilo does not exist"  
     else  
  $lilo > /dev/null  
     fi  
  fi  
     else  
  [ -n "$verbose" ] && echo "$liloConfig does not exist, not running grubby"  
     fi  
173    
174     if [[ -n ${cfgLilo} ]]
175     then
176     [[ -n ${verbose} ]] && echo "adding ${version} to ${liloConfig}"
177    
178     ${grubby} --add-kernel=${bootPrefix}/${kernelName}-${version} ${INITRD} \
179     --copy-default ${makedefault} --title ${version} \
180     ${mbkernel:+--add-multiboot="${mbkernel}"} ${mbargs:+--mbargs="${mbargs}"} \
181     --args="root=${rootdevice} ${kernargs}" --remove-kernel="TITLE=${version}" \
182     --${liloFlag}
183    
184     if [[ -n ${runLilo} ]]
185     then
186     [[ -n ${verbose} ]] && echo "running ${lilo}"
187     if [ ! -x $lilo ]
188     then
189     [[ -n ${verbose} ]] && echo "${lilo} does not exist"
190     else
191     ${lilo} > /dev/null
192     fi
193     fi
194     else
195     [[ -n ${verbose} ]] && echo "${liloConfig} does not exist, not running grubby"
196     fi
197  }  }
198    
199  remove() {  remove()
200      # FIXME: is this a good heuristic to find out if we're on iSeries?  {
201      if [ -d /proc/iSeries ]; then   # FIXME: is this a good heuristic to find out if we're on iSeries?
202   [ -n "$verbose" ] && echo "On an iSeries, remove img file"   if [ -d /proc/iSeries ]
203   rm -f $bootPrefix/$kernelName-$version.img 2>/dev/null   then
204   return   [[ -n ${verbose} ]] && echo "On an iSeries, remove img file"
205      fi   rm -f ${bootPrefix}/${kernelName}-${version}.img 2>/dev/null
206     return
207      if [ -n "$cfgGrub" ]; then   fi
208   [ -n "$verbose" ] && echo "removing $version from $grubConfig"  
209   $grubby --remove-kernel=$bootPrefix/$kernelName-$version   if [[ -n ${cfgGrub} ]]
210      else   then
211   [ -n "$verbose" ] && echo "$grubConfig does not exist, not running grubby"   [[ -n ${verbose} ]] && echo "removing ${version} from ${grubConfig}"
212      fi   ${grubby} --remove-kernel=${bootPrefix}/${kernelName}-${version}
213     else
214      if [ -n "$cfgLilo" ]; then   [[ -n ${verbose} ]] && echo "${grubConfig} does not exist, not running grubby"
215   [ -n "$verbose" ] && echo "removing $version from $liloConfig"   fi
216   $grubby --remove-kernel=$bootPrefix/$kernelName-$version    \  
217       --$liloFlag   if [[ -n ${cfgLilo} ]]
218     then
219   if [ -n "$runLilo" ]; then   [[ -n ${verbose} ]] && echo "removing ${version} from ${liloConfig}"
220      [ -n "$verbose" ] && echo "running $lilo"   ${grubby} --remove-kernel=${bootPrefix}/${kernelName}-${version}    \
221      if [ ! -x $lilo ] ; then   --${liloFlag}
222   [ -n "$verbose" ] && echo "$lilo does not exist"  
223      else   if [[ -n ${runLilo} ]]
224   $lilo > /dev/null   then
225      fi   [[ -n ${verbose} ]] && echo "running ${lilo}"
226   fi   if [ ! -x ${lilo} ]
227      else   then
228   [ -n "$verbose" ] && echo "$liloConfig does not exist, not running grubby"   [[ -n ${verbose} ]] && echo "${lilo} does not exist"
229      fi   else
230     ${lilo} > /dev/null
231     fi
232     fi
233     else
234     [[ -n ${verbose} ]] && echo "${liloConfig} does not exist, not running grubby"
235     fi
236  }  }
237    
238  update() {  update()
239      if [ -n "$cfgGrub" ]; then  {
240   [ -n "$verbose" ] && echo "updating $version from $grubConfig"   if [[ -n ${cfgGrub} ]]
241   $grubby --update-kernel=$bootPrefix/$kernelName-$version \   then
242      ${kernargs:+--args="$kernargs"} \   [[ -n ${verbose} ]] && echo "updating ${version} from ${grubConfig}"
243      ${removeargs:+--remove-args="$removeargs"}   ${grubby} --update-kernel=${bootPrefix}/${kernelName}-${version} \
244      else   ${kernargs:+--args="${kernargs}"} \
245   [ -n "$verbose" ] && echo "$grubConfig does not exist, not running grubby"   ${removeargs:+--remove-args="${removeargs}"}
246      fi   else
247     [[ -n ${verbose} ]] && echo "${grubConfig} does not exist, not running grubby"
248      if [ -n "$cfgLilo" ]; then   fi
249   [ -n "$verbose" ] && echo "updating $version from $liloConfig"  
250   $grubby --update-kernel=$bootPrefix/$kernelName-$version \   if [[ -n ${cfgLilo} ]]
251      ${kernargs:+--args="$kernargs"} \   then
252      ${removeargs:+--remove-args="$removeargs"} \   [[ -n ${verbose} ]] && echo "updating ${version} from ${liloConfig}"
253       --$liloFlag   ${grubby} --update-kernel=${bootPrefix}/${kernelName}-${version} \
254     ${kernargs:+--args="${kernargs}"} \
255   if [ -n "$runLilo" ]; then   ${removeargs:+--remove-args="${removeargs}"} \
256      [ -n "$verbose" ] && echo "running $lilo"   --${liloFlag}
257      if [ ! -x $lilo ] ; then  
258   [ -n "$verbose" ] && echo "$lilo does not exist"   if [[ -n ${runLilo} ]]
259      else   then
260   $lilo > /dev/null   [[ -n ${verbose} ]] && echo "running ${lilo}"
261      fi   if [ ! -x ${lilo} ]
262   fi   then
263      else   [[ -n ${verbose} ]] && echo "${lilo} does not exist"
264   [ -n "$verbose" ] && echo "$liloConfig does not exist, not running grubby"   else
265      fi   ${lilo} > /dev/null
266     fi
267     fi
268     else
269     [[ -n ${verbose} ]] && echo "${liloConfig} does not exist, not running grubby"
270     fi
271  }  }
272    
273  mkinitrd() {  mkinitrd()
274      [ -n "$verbose" ] && echo "creating initrd $initrdfile using $version"  {
275      /sbin/mkinitrd --allow-missing -f $initrdfile $version   [[ -n ${verbose} ]] && echo "creating initrd ${initrdfile} using ${version}"
276      rc=$?   /sbin/mkinitrd --allow-missing -f ${initrdfile} ${version}
277      if [ $rc != 0 ]; then   rc=$?
278   echo "mkinitrd failed" >&2   if [ ${rc} != 0 ]
279   exit 1   then
280      fi   echo "mkinitrd failed" >&2
281     exit 1
282     fi
283  }  }
284    
285  rminitrd() {  rminitrd()
286      [ -n "$verbose" ] && echo "removing initrd $initrdfile"  {
287      [ -f $initrdfile ] && rm -f $initrdfile   [[ -n ${verbose} ]] && echo "removing initrd ${initrdfile}"
288     [ -f ${initrdfile} ] && rm -f ${initrdfile}
289  }  }
290    
291  doDepmod() {  doDepmod()
292      [ -n "$verbose" ] && echo "running depmod for $version"  {
293      depmod -ae -F /boot/System.map-$version $version   [[ -n ${verbose} ]] && echo "running depmod for ${version}"
294     depmod -ae -F /boot/System.map-${version} ${version}
295  }  }
296    
297  doRmmoddep() {  doRmmoddep()
298      [ -n "$verbose" ] && echo "removing modules.dep info for $version"  {
299      [ -d /lib/modules/$version ] && rm -f /lib/modules/$version/modules.*       [[ -n ${verbose} ]] && echo "removing modules.dep info for ${version}"
300     [ -d /lib/modules/${version} ] && rm -f /lib/modules/${version}/modules.*
301  }  }
302    
303    
304  while [ $# -gt 0 ]; do  while [ $# -gt 0 ]
305      case $1 in  do
306   --mkinitrd)   case $1 in
307      initrd="make"   --mkinitrd)
308      ;;   initrd="make"
309     ;;
310   --rminitrd)  
311      initrd="remove"   --rminitrd)
312      ;;   initrd="remove"
313     ;;
314   --initrdfile*)  
315      if echo $1 | grep '=' >/dev/null ; then   --initrdfile*)
316       initrdfile=`echo $1 | sed 's/^--initrdfile=//'`   if echo $1 | grep '=' >/dev/null
317      else   then
318   initrdfile=$2   initrdfile=$(echo $1 | sed 's/^--initrdfile=//')
319   shift   else
320      fi       initrdfile=$2
321      ;;   shift
322     fi
323   --kernel-args*)   ;;
324      if echo $1 | grep '=' >/dev/null ; then  
325       kernargs=`echo $1 | sed 's/^--kernel-args=//'`   --kernel-args*)
326      else   if echo $1 | grep '=' >/dev/null
327   kernargs=$2   then
328   shift   kernargs=$(echo $1 | sed 's/^--kernel-args=//')
329      fi       else
330      ;;   kernargs=$2
331     shift
332   --remove-args*)   fi
333      if echo $1 | grep '=' >/dev/null ; then   ;;
334       removeargs=`echo $1 | sed 's/^--remove-args=//'`  
335      else   --remove-args*)
336   removeargs=$2   if echo $1 | grep '=' >/dev/null
337   shift   then
338      fi       removeargs=$(echo $1 | sed 's/^--remove-args=//')
339      ;;   else
340     removeargs=$2
341   --banner*)   shift
342      if echo $1 | grep '=' >/dev/null ; then   fi
343       banner=`echo $1 | sed 's/^--banner=//'`   ;;
344      else  
345   banner=$2   --banner*)
346   shift   if echo $1 | grep '=' >/dev/null
347      fi       then
348      ;;   banner=$(echo $1 | sed 's/^--banner=//')
349     else
350   --multiboot*)   banner=$2
351      if echo $1 |grep '=' >/dev/null; then   shift
352   mbkernel=`echo $1 | sed 's/^--multiboot=//'`   fi
353      else   ;;
354   # can't really support having an optional second arg here  
355   # sorry!   --multiboot*)
356   mbkernel="/boot/xen.gz"   if echo $1 |grep '=' >/dev/null
357      fi   then
358      ;;   mbkernel=$(echo $1 | sed 's/^--multiboot=//')
359     else
360   --mbargs*)   # can't really support having an optional second arg here
361      if echo $1 |grep '=' >/dev/null; then   # sorry!
362   mbargs=`echo $1 | sed 's/^--mbargs=//'`   mbkernel="/boot/xen.gz"
363      else   fi
364   mbargs="$2"   ;;
365   shift  
366      fi   --mbargs*)
367      ;;   if echo $1 |grep '=' >/dev/null
368     then
369   --depmod)   mbargs=$(echo $1 | sed 's/^--mbargs=//')
370      moddep="make"   else
371      ;;   mbargs="$2"
372     shift
373   --rmmoddep)   fi
374      moddep="remove"   ;;
375      ;;  
376     --depmod)
377   --make-default)   moddep="make"
378      makedefault="--make-default"   ;;
379      ;;  
380     --rmmoddep)
381   --package)   moddep="remove"
382      if echo $1 | grep '=' >/dev/null ; then   ;;
383       package=`echo $1 | sed 's/^--package=//'`  
384      else   --make-default)
385   package=$2   makedefault="--make-default"
386   shift   ;;
387      fi  
388      ;;   --package)
389     if echo $1 | grep '=' >/dev/null
390   -v)   then
391      verbose=-v   package=$(echo $1 | sed 's/^--package=//')
392      ;;   else
393     package=$2
394   *)   shift
395      if [ -z "$mode" ]; then   fi
396   mode=$1   ;;
397      elif [ -z "$version" ]; then  
398   version=$1   -v)
399      else   verbose=-v
400   usage   ;;
401      fi  
402      ;;   *)
403      esac   if [[ -z ${mode} ]]
404     then
405     mode=$1
406     elif [[ -z ${version} ]]
407     then
408     version=$1
409     else
410     usage
411     fi
412     ;;
413     esac
414    
415      shift   shift
416  done  done
417    
418  # make sure the mode is valid  # make sure the mode is valid
419  if [ "$mode" != "--install" -a "$mode" != "--remove" -a "$mode" != "--update" ] ; then  if [[ ${mode} != --install ]] && [[ ${mode} != --remove ]] && [[ ${mode} != --update ]]
420      usage  then
421     usage
422  fi  fi
423    
424  if [ -z "$version" ]; then  if [[ -z ${version} ]]
425      usage  then
426     usage
427  fi  fi
428    
429  if [ "$mode" != "--install" -a "$makedefault" ]; then  if [ "${mode}" != "--install" -a "${makedefault}" ]
430      usage  then
431     usage
432  fi  fi
433    
434  kernelmajor=`echo $kernel | cut -d . -f 1,2`  kernelmajor=$(echo ${kernel} | cut -d . -f 1,2)
435    
436  # kernel image for 2.4 is vmlinux  # kernel image for 2.4 is vmlinux
437  if [ $ARCH = 'ppc64' -o $ARCH = 'ppc' ]; then  if [[ ${ARCH} = ppc64 ]] || [[ ${ARCH} = ppc ]]
438    if [ "$kernelmajor" == "2.4" ]; then  then
439        kernelName=kernel   if [[ ${kernelmajor} = 2.4 ]]
440    fi   then
441     kernelName=kernel
442     fi
443  fi  fi
444    
   
445  # 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
446  if [ -z "$initrdfile" ]; then  if [[ -z ${initrdfile} ]]
447      INITRD_NAME_PREFIX="initrd"  then
448     INITRD_NAME_PREFIX="initrd"
449      if [ `uname -m` = "ia64" ]; then  
450   initrdfile="/boot/efi/EFI/redhat/$INITRD_NAME_PREFIX-$version.img"   if [[ $(uname -m) = ia64 ]]
451      else   then
452   initrdfile="/boot/$INITRD_NAME_PREFIX-$version.img"   initrdfile="/boot/efi/EFI/redhat/${INITRD_NAME_PREFIX}-${version}.img"
453      fi   else
454     initrdfile="/boot/${INITRD_NAME_PREFIX}-${version}.img"
455     fi
456  fi  fi
457  [ -n "$verbose" ] && echo "initrdfile is $initrdfile"  [[ -n ${verbose} ]] && echo "initrdfile is ${initrdfile}"
458    
459  # 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
460  if [ "$mode" == "--install" -a "$UPDATEDEFAULT" == "yes" -a -n "$package" -a -n "$DEFAULTKERNEL" -a "$package" == "$DEFAULTKERNEL" ]; then  if [[ ${mode} = --install ]] && [[ ${UPDATEDEFAULT} = yes ]] && [[ -n ${package} ]] &&
461      makedefault="--make-default"   [[ -n ${DEFAULTKERNEL} ]] && [[ ${package} = ${DEFAULTKERNEL} ]]
462      [ -n "$verbose" ] && echo "making it the default based on config"  then
463     makedefault="--make-default"
464     [[ -n ${verbose} ]] && echo "making it the default based on config"
465  fi  fi
466    
467  if [ "$moddep" == "make" ]; then  if [[ ${moddep} = make ]]
468      doDepmod  then
469  elif [ "$moddep" == "remove" ]; then   doDepmod
470      doRmmoddep  elif [[ ${moddep} = remove ]]
471    then
472     doRmmoddep
473  fi  fi
474    
475  if [ "$initrd" == "make" ]; then  if [[ ${initrd} = make ]]
476      mkinitrd  then
477  elif [ "$initrd" == "remove" ]; then   mkinitrd
478      rminitrd  elif [[ ${initrd} = remove ]]
479    then
480     rminitrd
481  fi  fi
482    
483  if [ ! -x $grubby ] ; then  if [ ! -x ${grubby} ]
484      [ -n "$verbose" ] && echo "$grubby does not exist"  then
485      exit 0   [[ -n ${verbose} ]] && echo "${grubby} does not exist"
486     exit 0
487  fi  fi
488    
489  [ -n "$grubConfig" ] && [ -f "$grubConfig" ] && cfgGrub=1;  [[ -n ${grubConfig} ]] && [ -f ${grubConfig} ] && cfgGrub=1
490  [ -n "$liloConfig" ] && [ -f "$liloConfig" ] && cfgLilo=1;  [[ -n ${liloConfig} ]] && [ -f ${liloConfig} ] && cfgLilo=1
491    
492  # 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
493  # is lilo to determine if it should be run  # is lilo to determine if it should be run
494  if [ -n "$cfgLilo" -a -n "$isx86" ]; then  if [[ -n ${cfgLilo} ]] && [[ -n ${isx86} ]]
495      runLilo=$($grubby --bootloader-probe | grep lilo)  then
496     runLilo=$(${grubby} --bootloader-probe | grep lilo)
497  fi  fi
498    
499  if [ "$mode" == "--install" ]; then  if [[ ${mode} = --install ]]
500      install  then
501  elif [ "$mode" == "--remove" ]; then   install
502      remove  elif [[ ${mode} = --remove ]]
503  elif [ "$mode" == "--update" ]; then  then
504      update   remove
505    elif [[ ${mode} = --update ]]
506    then
507     update
508  fi  fi
509    
510  exit 0  exit 0

Legend:
Removed from v.923  
changed lines
  Added in v.924