Magellan Linux

Diff of /tags/grubby-8_7/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 1728 by niro, Sat Feb 18 00:59:04 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    cfgExtlinux=""
50  cfguBoot=""  cfguBoot=""
51  runLilo=""  runLilo=""
52  grubConfig=""  grubConfig=""
53    grub2Config=""
54    grub2EfiConfig=""
55    extlinuxConfig=""
56    
57  ARCH=$(uname -m)  ARCH=$(uname -m)
58    
# Line 96  else Line 102  else
102   # this leaves i?86 and x86_64   # this leaves i?86 and x86_64
103   liloConfig=/etc/lilo.conf   liloConfig=/etc/lilo.conf
104   grubConfig=/boot/grub/grub.conf   grubConfig=/boot/grub/grub.conf
105     grub2Config=/boot/grub/grub.cfg
106     grub2EfiConfig=/boot/grub/grub-efi.cfg
107     extlinuxConfig=/boot/extlinux/extlinux.conf
108   bootPrefix=/boot   bootPrefix=/boot
109   liloFlag=lilo   liloFlag=lilo
110   isx86="yes"   isx86="yes"
# Line 111  moddep="" Line 120  moddep=""
120  verbose=""  verbose=""
121  makedefault=""  makedefault=""
122  package=""  package=""
123  mbkernel=""  mbkernel="${HYPERVISOR}"
124  mbargs=""  mbargs="${HYPERVISOR_ARGS}"
125  adddracutargs=""  adddracutargs=""
126  addplymouthinitrd=""  addplymouthinitrd=""
127    
# Line 130  usage() Line 139  usage()
139   exit 1   exit 1
140  }  }
141    
 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  
 }  
   
142  install()  install()
143  {  {
144   # 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 176  install()
176   return   return
177   fi   fi
178    
  # Run grub2's configuration update in parallel, if it is installed  
  run_grub2  
   
179   # get the root filesystem to use   # get the root filesystem to use
180   rootdevice=$(awk '{ if ($1 !~ /^[ \t]*#/ && $2 == "/") { print $1; }}' /etc/fstab)   rootdevice=$(awk '{ if ($1 !~ /^[ \t]*#/ && $2 == "/") { print $1; }}' /etc/fstab)
181    
# Line 201  install() Line 198  install()
198   else   else
199   title="Magellan Linux (${version})"   title="Magellan Linux (${version})"
200   fi   fi
201   ${grubby} --add-kernel=${bootPrefix}/${kernelName}-${version} \   ${grubby} --grub -c ${grubConfig} \
202     --add-kernel=${bootPrefix}/${kernelName}-${version} \
203   ${INITRD} --copy-default ${makedefault} --title "${title}" \   ${INITRD} --copy-default ${makedefault} --title "${title}" \
204   ${mbkernel:+--add-multiboot="${mbkernel}"} ${mbargs:+--mbargs="${mbargs}"} \   ${mbkernel:+--add-multiboot="${mbkernel}"} ${mbargs:+--mbargs="${mbargs}"} \
205   --args="root=${rootdevice} ${kernargs}" --remove-kernel="TITLE=${title}"   --args="root=${rootdevice} ${kernargs}" --remove-kernel="TITLE=${title}"
206   else   else
207   [[ -n ${verbose} ]] && echo "${grubConfig} does not exist, not running grubby"   [[ -n ${verbose} ]] && echo "${grubConfig} does not exist, not running grubby for grub 0.97"
208     fi
209     if [[ -n ${cfgGrub2} ]]
210     then
211     [[ -n ${verbose} ]] && echo "adding ${version} to ${grub2Config}"
212    
213     if [[ -n ${banner} ]]
214     then
215     title="${banner} (${version})"
216     elif [ -f /etc/mageversion ]
217     then
218     title="Magellan Linux $(< /etc/mageversion) (${version})"
219     else
220     title="Magellan Linux (${version})"
221     fi
222     ${grubby} --grub2 -c ${grub2Config} \
223     --add-kernel=${bootPrefix}/${kernelName}-${version} \
224     ${INITRD} --copy-default ${makedefault} --title "${title}" \
225     ${mbkernel:+--add-multiboot="${mbkernel}"} \
226     ${mbargs:+--mbargs="${mbargs}"} \
227     --args="root=${rootdevice} ${kernargs}" --remove-kernel="TITLE=${title}"
228     else
229     [[ -n ${verbose} ]] && echo "${grub2Config} does not exist, not running grubby for grub 2"
230     fi
231     if [[ -n ${cfgGrub2Efi} ]]
232     then
233     [[ -n ${verbose} ]] && echo "adding ${version} to ${grub2EfiConfig}"
234    
235     if [[ -n ${banner} ]]
236     then
237     title="${banner} (${version})"
238     elif [ -f /etc/mageversion ]
239     then
240     title="Magellan Linux $(< /etc/mageversion) (${version})"
241     else
242     title="Magellan Linux (${version})"
243     fi
244     ${grubby} --grub2 -c ${grub2EfiConfig} \
245     --add-kernel=${bootPrefix}/${kernelName}-${version} \
246     ${INITRD} --copy-default ${makedefault} --title "${title}" \
247     ${mbkernel:+--add-multiboot="${mbkernel}"} \
248     ${mbargs:+--mbargs="${mbargs}"} \
249     --args="root=${rootdevice} ${kernargs}" --remove-kernel="TITLE=${title}"
250     else
251     [[ -n ${verbose} ]] && echo "${grub2EfiConfig} does not exist, not running grubby for grub 2 with UEFI"
252   fi   fi
253    
254   if [[ -n ${cfgLilo} ]]   if [[ -n ${cfgLilo} ]]
# Line 232  install() Line 274  install()
274   else   else
275   [[ -n ${verbose} ]] && echo "${liloConfig} does not exist, not running grubby"   [[ -n ${verbose} ]] && echo "${liloConfig} does not exist, not running grubby"
276   fi   fi
277    
278     if [[ -n ${cfgExtlinux} ]]
279     then
280     [[ -n ${verbose} ]] && echo "adding ${version} to ${extlinuxConfig}"
281    
282     if [[ -n ${banner} ]]
283     then
284     title="${banner} (${version})"
285     elif [ -f /etc/mageversion ]
286     then
287     title="Magellan Linux $(< /etc/mageversion) (${version})"
288     else
289     title="Magellan Linux (${version})"
290     fi
291     ${grubby} --extlinux -c ${extlinuxConfig} \
292     --add-kernel=${bootPrefix}/${kernelName}-${version} \
293     ${INITRD} --copy-default ${makedefault} --title "${title}" \
294     ${mbkernel:+--add-multiboot="${mbkernel}"} ${mbargs:+--mbargs="${mbargs}"} \
295     --args="root=${rootdevice} ${kernargs}" --remove-kernel="TITLE=${title}"
296     else
297     [[ -n ${verbose} ]] && echo "${extlinuxConfig} does not exist, not running grubby for extlinux"
298     fi
299  }  }
300    
301  remove()  remove()
# Line 244  remove() Line 308  remove()
308   return   return
309   fi   fi
310    
  # Run grub2's configuration update in parallel, if it is installed  
  run_grub2  
   
311   if [[ -n ${cfgGrub} ]]   if [[ -n ${cfgGrub} ]]
312   then   then
313   [[ -n ${verbose} ]] && echo "removing ${version} from ${grubConfig}"   [[ -n ${verbose} ]] && echo "removing ${version} from ${grubConfig}"
314   ${grubby} --remove-kernel=${bootPrefix}/${kernelName}-${version}   ${grubby} --grub -c ${grubConfig} \
315     --remove-kernel=${bootPrefix}/${kernelName}-${version}
316   else   else
317   [[ -n ${verbose} ]] && echo "${grubConfig} does not exist, not running grubby"   [[ -n ${verbose} ]] && echo "${grubConfig} does not exist, not running grubby for grub 0.97"
318     fi
319     if [[ -n ${cfgGrub2} ]]
320     then
321     [[ -n ${verbose} ]] && echo "removing ${version} from ${grub2Config}"
322     ${grubby} --grub2 -c ${grub2Config} \
323     --remove-kernel=${bootPrefix}/${kernelName}-${version}
324     else
325     [[ -n ${verbose} ]] && echo "${grub2Config} does not exist, not running grubby for grub 2"
326     fi
327     if [[ -n ${cfgGrub2Efi} ]]
328     then
329     [[ -n ${verbose} ]] && echo "removing ${version} from ${grub2EfiConfig}"
330     ${grubby} --grub2 -c ${grub2EfiConfig} \
331     --remove-kernel=${bootPrefix}/${kernelName}-${version}
332     else
333     [[ -n ${verbose} ]] && echo "${grub2EfiConfig} does not exist, not running grubby grub 2 with UEFI"
334   fi   fi
335    
336   if [[ -n ${cfgLilo} ]]   if [[ -n ${cfgLilo} ]]
# Line 327  remove() Line 405  remove()
405   else   else
406   [[ -n ${verbose} ]] && echo "${ubootScript} does not exist, not modifying ${ubootDir}"   [[ -n ${verbose} ]] && echo "${ubootScript} does not exist, not modifying ${ubootDir}"
407   fi   fi
408    
409     if [[ -n ${cfgExtlinux} ]]
410     then
411     [[ -n ${verbose} ]] && echo "removing ${version} from ${extlinuxConfig}"
412     ${grubby} --extlinux -c ${extlinuxConfig} \
413     --remove-kernel=${bootPrefix}/${kernelName}-${version}
414     else
415     [[ -n ${verbose} ]] && echo "${extlinuxConfig} does not exist, not running grubby for extlinux"
416     fi
417  }  }
418    
419  update()  update()
# Line 349  update() Line 436  update()
436   fi   fi
437   fi   fi
438    
  # Run grub2's configuration update in parallel, if it is installed  
  run_grub2  
   
439   if [[ -n ${cfgGrub} ]]   if [[ -n ${cfgGrub} ]]
440   then   then
441   [[ -n ${verbose} ]] && echo "updating ${version} from ${grubConfig}"   [[ -n ${verbose} ]] && echo "updating ${version} from ${grubConfig}"
442   ${grubby} --update-kernel=${bootPrefix}/${kernelName}-${version} \   ${grubby} --grub -c ${grubConfig} \
443     --update-kernel=${bootPrefix}/${kernelName}-${version} \
444   ${INITRD} \   ${INITRD} \
445   ${kernargs:+--args="${kernargs}"} \   ${kernargs:+--args="${kernargs}"} \
446   ${removeargs:+--remove-args="${removeargs}"}   ${removeargs:+--remove-args="${removeargs}"}
# Line 363  update() Line 448  update()
448   [[ -n ${verbose} ]] && echo "${grubConfig} does not exist, not running grubby"   [[ -n ${verbose} ]] && echo "${grubConfig} does not exist, not running grubby"
449   fi   fi
450    
451     if [[ -n ${cfgGrub2} ]]
452     then
453     [[ -n ${verbose} ]] && echo "updating ${version} from ${grub2Config}"
454     ${grubby} --grub2 -c ${grub2Config} \
455     --update-kernel=${bootPrefix}/${kernelName}-${version} \
456     ${INITRD} \
457     ${kernargs:+--args="${kernargs}"} \
458     ${removeargs:+--remove-args="${removeargs}"}
459     else
460     [[ -n ${verbose} ]] && echo "${grub2Config} does not exist, not running grubby"
461     fi
462    
463     if [[ -n ${cfgGrub2Efi} ]]
464     then
465     [[ -n ${verbose} ]] && echo "updating ${version} from ${grub2EfiConfig}"
466     ${grubby} --grub2 -c ${grub2EfiConfig} \
467     --update-kernel=${bootPrefix}/${kernelName}-${version} \
468     ${INITRD} \
469     ${kernargs:+--args="${kernargs}"} \
470     ${removeargs:+--remove-args="${removeargs}"}
471     else
472     [[ -n ${verbose} ]] && echo "${grub2EfiConfig} does not exist, not running grubby"
473     fi
474    
475   if [[ -n ${cfgLilo} ]]   if [[ -n ${cfgLilo} ]]
476   then   then
477   [[ -n ${verbose} ]] && echo "updating ${version} from ${liloConfig}"   [[ -n ${verbose} ]] && echo "updating ${version} from ${liloConfig}"
# Line 417  update() Line 526  update()
526   else   else
527   [[ -n ${verbose} ]] && echo "${ubootScript} does not exist, not setting up ${ubootDir}"   [[ -n ${verbose} ]] && echo "${ubootScript} does not exist, not setting up ${ubootDir}"
528   fi   fi
529    
530     if [[ -n ${cfgExtlinux} ]]
531     then
532     [[ -n ${verbose} ]] && echo "updating ${version} from ${extlinuxConfig}"
533     ${grubby} --extlinux -c ${extlinuxConfig} \
534     --update-kernel=${bootPrefix}/${kernelName}-${version} \
535     ${INITRD} \
536     ${kernargs:+--args="${kernargs}"} \
537     ${removeargs:+--remove-args="${removeargs}"}
538     else
539     [[ -n ${verbose} ]] && echo "${extlinuxConfig} does not exist, not running grubby"
540     fi
541  }  }
542    
543  mkinitrd()  mkinitrd()
544  {  {
545   if [[ -n ${dracut} ]]   if [[ -n ${dracut} ]]
546   then   then
547   tool="/sbin/dracut ${dracuthostonly} -f ${initrdfile} ${version}"   tool="dracut ${dracuthostonly} -f ${initrdfile} ${version}"
548   else   else
549   tool="/sbin/mkinitrd --allow-missing -f ${initrdfile} ${version}"   tool="/sbin/mkinitrd --allow-missing -f ${initrdfile} ${version}"
550   fi   fi
# Line 679  then Line 800  then
800  fi  fi
801    
802  [[ -n ${grubConfig} ]] && [ -f ${grubConfig} ] && cfgGrub=1  [[ -n ${grubConfig} ]] && [ -f ${grubConfig} ] && cfgGrub=1
803    [[ -n ${grub2Config} ]] && [ -f ${grub2Config} ] && cfgGrub2=1
804    [[ -n ${grub2EfiConfig} ]] && [ -f ${grub2EfiConfig} ] && cfgGrub2Efi=1
805  [[ -n ${liloConfig} ]] && [ -f ${liloConfig} ] && cfgLilo=1  [[ -n ${liloConfig} ]] && [ -f ${liloConfig} ] && cfgLilo=1
806    [[ -n ${extlinuxConfig} ]] && [ -f ${extlinuxConfig} ] && cfgExtlinux=1
807    
808  # if we have a uBoot directory, check if it is mounted.  # if we have a uBoot directory, check if it is mounted.
809  # if not, mount it. Then check if a boot script exists.  # if not, mount it. Then check if a boot script exists.

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