Magellan Linux

Diff of /tags/grubby-8_15/new-kernel-pkg

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

revision 1691 by niro, Fri Feb 17 23:10:15 2012 UTC revision 1697 by niro, Sat Feb 18 00:15:09 2012 UTC
# Line 42  fi Line 42  fi
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=""
# Line 96  else Line 98  else
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"
# Line 130  usage() Line 134  usage()
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)
# Line 176  install() Line 171  install()
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    
# Line 201  install() Line 193  install()
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} ]]
# Line 244  remove() Line 280  remove()
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} ]]
# Line 349  update() Line 398  update()
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}"
# Line 363  update() Line 409  update()
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}"
# Line 679  then Line 749  then
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.

Legend:
Removed from v.1691  
changed lines
  Added in v.1697