Magellan Linux

Diff of /alx-src/trunk/alxinstall-ng/bin/alxinstall-ng.sh.in

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

alx-src/trunk/alxinstall-ng/bin/alxinstall-ng.sh revision 527 by niro, Fri Jun 27 23:33:40 2008 UTC alx-src/trunk/alxinstall-ng/bin/alxinstall-ng.sh.in revision 4847 by niro, Mon May 13 12:11:18 2013 UTC
# Line 1  Line 1 
1  #!/bin/sh  #!/bin/sh
2  #  #
3  # $Header: /home/cvsd/alx-cvs/alx-src/alxinstall-ng/bin/alxinstall-ng.sh,v 1.13 2008-06-27 23:33:40 niro Exp $  # $Header: /home/cvsd/alx-cvs/alx-src/alxinstall-ng/bin/alxinstall-ng.sh,v 1.15 2008-06-28 00:37:45 niro Exp $
4  #  #
5  # AutoSta_LX Installation Script  # AutoSta_LX Installation Script
6  #  #
# Line 21  cdromdev="$(echo ${cdromdev} | sed 's/ / Line 21  cdromdev="$(echo ${cdromdev} | sed 's/ /
21  ########################################  ########################################
22    
23  ### System/Config Version  ### System/Config Version
24  VERSION="0.3"  VERSION="%VERSIONTAG%"
25  TITLE="alxinstall-ng - ${VERSION}"  TITLE="alxinstall-ng - ${VERSION}"
26    
27  CDPATH="/mnt/cdrom"  CDPATH="/mnt/cdrom"
# Line 31  INSTALLPATH="/mnt/magellan" Line 31  INSTALLPATH="/mnt/magellan"
31  CURRENTLINE=0  CURRENTLINE=0
32  #TOTALLINES=11072 # -> now in images.conf  #TOTALLINES=11072 # -> now in images.conf
33    
34    # standard kernel opts
35    KERNELOPTS="quiet video=1024x768"
36    
37    # grub options
38    GRUBLEGACYOPTS=""
39    GRUB2OPTS=""
40    
41    # fdisk options
42    FDISKPARTIONBELOW256MB=0
43    
44    # default specialdevices
45    SPECIALDEVICE=""
46    
47    # target filesystem
48    FORMAT_FILESYSTEM="ext4"
49    
50  #################################################  #################################################
51  #  DIALOG BOXEN #  #  DIALOG BOXEN #
# Line 92  dialog_setup_hdd_info_flash() Line 107  dialog_setup_hdd_info_flash()
107   Bitte ${SHDD}1 als \Z3bootable\Zn markieren." 12 81   Bitte ${SHDD}1 als \Z3bootable\Zn markieren." 12 81
108  }  }
109    
110    dialog_setup_hdd_info_auto()
111    {
112     local SHDD="$(echo $HDD | sed 's/\/dev\///')"
113    
114     dialog \
115     --colors \
116     --title "[ Festplatten Partitionierung ]" \
117     --backtitle "${TITLE}" \
118     --ok-label "Weiter" \
119     --msgbox "\nAchtung!\n\
120     Alle Daten werden von der Disk [ \Z3${HDD}\Zn ] gelöscht!" 12 81
121    }
122    
123  dialog_setup_system_menu()  dialog_setup_system_menu()
124  {  {
125   local i   local i
# Line 102  dialog_setup_system_menu() Line 130  dialog_setup_system_menu()
130   --cancel-label "Abbrechen" \   --cancel-label "Abbrechen" \
131   --ok-label "Weiter" \   --ok-label "Weiter" \
132   --stdout \   --stdout \
133     --colors \
134   --menu "\nWaehlen Sie die Installations-Methode" 14 70 5 \   --menu "\nWaehlen Sie die Installations-Methode" 14 70 5 \
135   "1" "Normale IDE-Disk" \   "1" "Automatisches Setup (Empfohlen)" \
136   "2" "Flash-Speicher")   "" "" \
137     "" "\Z1Experten Modi:\Zn" \
138     "2" "Normale IDE-Disk (Manuell)" \
139     "3" "Flash-Speicher (Manuell)")
140   RES=$?   RES=$?
141   [[ ${RES} -eq 1 ]] && return 1   [[ ${RES} -eq 1 ]] && return 1
142   if [[ ${RES} -eq 0 ]]   if [[ ${RES} -eq 0 ]]
143   then   then
144   case "${i}" in   case "${i}" in
145           "1") run_install_normal ;;   "1") run_install_auto ;;
146   "2") run_install_flash ;;           "2") run_install_normal ;;
147     "3") run_install_flash ;;
148     "") dialog_setup_system_menu;;
149   esac   esac
150   fi   fi
151  }  }
152    
153  dialog_setup_hdd_found_manuell()  dialog_hardware_detection()
154  {  {
155   local i   local i
156     local hwtmp
157    
158     if [ -x $(which mktemp &> /dev/null) ]
159     then
160     hwtmp="$(mktemp)"
161     else
162     hwtmp="/tmp/hwtmp.sh"
163     fi
164    
165   [[ ! -z ${installdevs} ]] && installdevs=""   [[ ! -z ${installdevs} ]] && installdevs=""
166    
167   echo "dialog \\"  > /tmp/hddtmp.sh   echo "dialog \\"  > ${hwtmp}
168   echo "--backtitle \"${TITLE}\" \\" >> /tmp/hddtmp.sh   echo "--backtitle \"${TITLE}\" \\" >> ${hwtmp}
169   echo "--ok-label \"Weiter\" \\" >> /tmp/hddtmp.sh   echo "--ok-label \"Weiter\" \\" >> ${hwtmp}
170   echo "--stdout \\" >> /tmp/hddtmp.sh   echo "--stdout \\" >> ${hwtmp}
171   echo "--colors \\" >> /tmp/hddtmp.sh   echo "--colors \\" >> ${hwtmp}
172   echo "--msgbox \"Gefundene Hardware:\n\n \\" >> /tmp/hddtmp.sh   echo "--msgbox \"Gefundene Hardware:\n\n \\" >> ${hwtmp}
173   echo " Festplatten:\n \\" >> /tmp/hddtmp.sh   echo " Festplatten:\n \\" >> ${hwtmp}
174    
175   if [[ ! -z ${scsidisks} ]]   if [[ ! -z ${scsidisks} ]]
176   then   then
# Line 136  dialog_setup_hdd_found_manuell() Line 178  dialog_setup_hdd_found_manuell()
178   do   do
179   if [[ ${i} != ${cdromdev} ]]   if [[ ${i} != ${cdromdev} ]]
180   then   then
181   echo " \\Z7SCSI: \\Z3${i}\\Zn\n \\" >> /tmp/hddtmp.sh   echo " \\Z7SCSI: \\Z3${i}\\Zn\n \\" >> ${hwtmp}
182   installdevs="${installdevs} ${i}"   installdevs="${installdevs} ${i}"
183   fi   fi
184   done   done
# Line 148  dialog_setup_hdd_found_manuell() Line 190  dialog_setup_hdd_found_manuell()
190   do   do
191   if [[ ${i} != ${cdromdev} ]]   if [[ ${i} != ${cdromdev} ]]
192   then   then
193   echo " \\Z7IDE:  \\Z3${i}\\Zn\n \\" >> /tmp/hddtmp.sh   echo " \\Z7IDE:  \\Z3${i}\\Zn\n \\" >> ${hwtmp}
194   installdevs="${installdevs} ${i}"   installdevs="${installdevs} ${i}"
195   fi   fi
196   done   done
# Line 156  dialog_setup_hdd_found_manuell() Line 198  dialog_setup_hdd_found_manuell()
198    
199   if [[ ! -z ${cdromdev} ]]   if [[ ! -z ${cdromdev} ]]
200   then   then
201   echo " \n \\" >> /tmp/hddtmp.sh   echo " \n \\" >> ${hwtmp}
202   echo " \\Z7andere Laufwerke:\n \\" >> /tmp/hddtmp.sh   echo " \\Z7andere Laufwerke:\n \\" >> ${hwtmp}
203   echo " CDROM: \\Z3${cdromdev}\\Zn\n \\" >> /tmp/hddtmp.sh   echo " CDROM: \\Z3${cdromdev}\\Zn\n \\" >> ${hwtmp}
204   fi   fi
205   echo " \" 13 70" >> /tmp/hddtmp.sh  
206   chmod a+x /tmp/hddtmp.sh   # other devices
207   /tmp/hddtmp.sh   run_hardware_detection
208     case "${SPECIALDEVICE}" in
209     zotac*) echo " \n\n\n \\Z2Zotac Device erkannt!\\Zn \\" >> ${hwtmp} ;;
210     rangee) echo " \n\n\n \\Z2Rangee Device erkannt!\\Zn \\" >> ${hwtmp} ;;
211     maxdata) echo " \n\n\n \\Z2Maxdata Device erkannt!\\Zn \\" >> ${hwtmp} ;;
212     *) echo " \n\n\n \\ZnStandard Device erkannt!\\Zn \\" >> ${hwtmp} ;;
213     esac
214    
215     echo " \" 13 70" >> ${hwtmp}
216     chmod a+x ${hwtmp}
217     ${hwtmp}
218    
219     # remove tmp file
220     if [[ -f ${hwtmp} ]]
221     then
222     rm ${hwtmp}
223     fi
224  }  }
225    
226  dialog_setup_hdd_partitions_manuell()  dialog_setup_hdd_partitions_manuell()
# Line 241  dialog_setup_hdd_partitions_manuell_flas Line 299  dialog_setup_hdd_partitions_manuell_flas
299   fi   fi
300  }  }
301    
302    dialog_setup_hdd_partitions_auto()
303    {
304     local i
305    
306     if [[ -z ${installdevs} ]]
307     then
308     dialog \
309     --backtitle "${TITLE}" \
310     --ok-label "Beenden" \
311     --msgbox "Kein geeignetes Laufwerk gefunden.\nDie Installation ist fehlgeschlagen." 6 70
312     exit 1
313     else
314    
315     echo "dialog \\" > /tmp/hddtmp.sh
316     echo "--backtitle \"${TITLE}\" \\" >> /tmp/hddtmp.sh
317     echo "--ok-label \"Weiter\" \\" >> /tmp/hddtmp.sh
318     echo "--cancel-label \"Beenden\" \\" >> /tmp/hddtmp.sh
319     echo "--stdout \\" >> /tmp/hddtmp.sh
320     echo "--menu \"Installations Laufwerk auswaehlen:\" 10 70 3 \\" >> /tmp/hddtmp.sh
321    
322     for i in ${installdevs}
323     do
324     echo "\"${i}\" \"\" \\" >> /tmp/hddtmp.sh
325     done
326     echo -e "\n" >> /tmp/hddtmp.sh
327    
328     chmod a+x /tmp/hddtmp.sh
329     HDD="$(/tmp/hddtmp.sh)"
330     RES=$?
331     [[ ${RES} -eq 1 ]] && return 1
332     if [[ ${RES} -eq 0 ]]
333     then
334     dialog_setup_hdd_info_auto
335     dialog_setup_hdd_create_partitions
336     setup_hdd_partitions_auto
337     fi
338     fi
339    }
340    
341    dialog_setup_hdd_create_partitions()
342    {
343     dialog \
344     --backtitle "${TITLE}" \
345     --infobox "Erstelle Disk Partitionen ..." 3 70
346    }
347    
348  dialog_setup_hdd_format()  dialog_setup_hdd_format()
349  {  {
350   dialog \   dialog \
# Line 323  dialog_main() Line 427  dialog_main()
427   then   then
428   case ${METHOD} in   case ${METHOD} in
429           "1") dialog_setup_system_menu ;;           "1") dialog_setup_system_menu ;;
430   "2") dialog_setup_hdd_found_manuell ;;   "2") dialog_hardware_detection ;;
431   "3") install_do_reboot ;;   "3") install_do_reboot ;;
432   "4") /bin/bash --login -i ;;   "4") /bin/bash --login -i ;;
433   esac   esac
# Line 334  dialog_main() Line 438  dialog_main()
438  #################################################  #################################################
439  # Install Komandos #  # Install Komandos #
440  #################################################  #################################################
441    run_hardware_detection()
442    {
443     local hwinfo
444    
445     hwinfo="$(hwinfo --bios --storage --pci --gfxcard)"
446    
447     # check for special devices/clients:
448     # if zotac a zotac and the disk is a removeable device, then add rootdelay to kernelcmd
449     local removable=0
450     if [[ ! -z $(echo "${hwinfo}" | grep -i zotac) ]]
451     then
452     for i in /sys/block/[hs]d*/removable
453     do
454     if [[ $(< ${i}) = 1 ]]
455     then
456     removable=1
457     fi
458     done
459    
460     # only add this for grub legacy, grub2 detect these settings on its own
461     export GRUBLEGACYOPTS="rootdelay=8"
462     # there are to zotac types in the wild, nvidia based gfx and intel
463     if [[ ! -z $(echo "${hwinfo}" | grep -i nouveau) ]]
464     then
465     export SPECIALDEVICE="zotac_nvidia"
466     else
467     export SPECIALDEVICE="zotac_intel"
468     fi
469     fi
470    
471     # check for special devices/clients:
472     # if a rangee and disk ist smaller then 256mb move partion one block further ahead
473     if [[ ! -z $(echo "${hwinfo}" | grep -i CLE266) ]]
474     then
475     # for a rangee always define partion startblock +1
476     export FDISKPARTIONBELOW256MB="1"
477     export SPECIALDEVICE="rangee"
478     export GRUBLEGACYOPTS=""
479     fi
480    
481     # check for special devices/clients:
482     # check for maxdata / i810/ i815 Chipsets and disable KMS and use i810fb frambuffer
483     if [[ ! -z $(echo "${hwinfo}" | grep -i i810) ]] || [[ ! -z $(echo "${hwinfo}" | grep -i i815) ]]
484     then
485     export SPECIALDEVICE="maxdata"
486     export GRUBLEGACYOPTS=""
487     fi
488    }
489    
490    hdd_size_below_256mb()
491    {
492     local hdd="$1"
493     local size
494     local retval
495     [[ -z ${hdd} ]] && die "Error: get_hdd_size() no \$hdd given!"
496    
497     size=$(fdisk -l ${hdd} | grep "Disk.*${hdd}" | sed 's:.*,\ \(.*\)\ byte.*:\1:')
498     if [[ ${size} -le 257000000 ]]
499     then
500     retval="0"
501     else
502     retval="1"
503     fi
504    
505     return "${retval}"
506    }
507    
508    setup_hdd_partitions_auto()
509    {
510     ROOTHDD="${HDD}1"
511    
512     # run this only if FDISKPARTITIONBELOW256MB is not already 1
513     if [[ ${FDISKPARTIONBELOW256MB} != 1 ]]
514     then
515     if hdd_size_below_256mb ${HDD}
516     then
517     FDISKPARTIONBELOW256MB=1
518     else
519     FDISKPARTIONBELOW256MB=0
520     fi
521     fi
522    
523     ## delete disk
524     dd if=/dev/zero of=${HDD} count=1 &> /dev/null || die
525    
526     if [[ ${FDISKPARTIONBELOW256MB} = 1 ]]
527     then
528     ## setup one bootable partition
529     #1. n= new disk
530     #2. p= primary disk
531     #3. 1= first partition
532     #4. 2= default sector start // small disk needs more space for grub2 mbr sector
533     #5. ''= defaul sector end
534     #6. a= bootable flag
535     #7. 1= boot flag for partition 1
536     #8. w= write/quit
537     fdisk ${HDD} &> /dev/null << EOF
538    n
539    p
540    1
541    2
542    
543    a
544    1
545    w
546    EOF
547     else
548     ## setup one bootable partition
549     #1. n= new disk
550     #2. p= primary disk
551     #3. 1= first partition
552     #4. ''= default sector start
553     #5. ''= defaul sector end
554     #6. a= bootable flag
555     #7. 1= boot flag for partition 1
556     #8. w= write/quit
557     fdisk ${HDD} &> /dev/null << EOF
558    n
559    p
560    1
561    
562    
563    a
564    1
565    w
566    EOF
567     fi
568    }
569    
570  setup_hdd_partitions_manuell()  setup_hdd_partitions_manuell()
571  {  {
572   BOOTHDD="${HDD}1"   BOOTHDD="${HDD}1"
# Line 387  install_system_image() Line 620  install_system_image()
620    
621  install_bootsector_chroot()  install_bootsector_chroot()
622  {  {
623   ### grubconf schreiben   local my_roothdd
624   source ${INSTALLPATH}/boot/kernelversion   local grubconf=${INSTALLPATH}/boot/grub/grub.conf
625     local grub2conf=/boot/grub/grub.cfg
626    
627   #for alx only   # check for grub2
628   if [ -e ${INSTALLPATH}/etc/alx_version ]   if [[ -f ${INSTALLPATH}/sbin/grub-mkconfig ]]
629   then   then
630   OLD_ALXVER="${ALXVER}"   # needed by grub-mkconfig on the first run
631   source ${INSTALLPATH}/etc/alx_version   if [[ ! -f ${INSTALLPATH}/boot/grub/video.lst ]]
632   KRNVER="ALX-${ALXVER}"   then
633   ALXVER="${OLD_ALXVER}"   install -m0644 ${INSTALLPATH}/lib/grub/*/video.lst ${INSTALLPATH}/boot/grub/video.lst || die
634   fi   fi
635    
636     # set kernelopts
637     if [[ -f ${INSTALLPATH}/etc/conf.d/grub ]]
638     then
639     sed -i "s:^\(export GRUB_CMDLINE_LINUX_DEFAULT=\).*:\1\"${KERNELOPTS}\":" ${INSTALLPATH}/etc/conf.d/grub || die
640     else
641     echo "export GRUB_CMDLINE_LINUX_DEFAULT=\"${KERNELOPTS}\"" >  ${INSTALLPATH}/etc/conf.d/grub || die
642     fi
643     echo 'grub-mkdevicemap' > ${INSTALLPATH}/root/.installrc || die
644     echo "LC_ALL=C grub-mkconfig -o ${grub2conf}  &> /dev/null" >> ${INSTALLPATH}/root/.installrc || die
645     echo "grub-install --no-floppy ${HDD} &> /dev/null" >> ${INSTALLPATH}/root/.installrc || die
646     echo "exit 0" >> ${INSTALLPATH}/root/.installrc || die
647    
648   [[ -z ${KRNVER} ]] && KRNVER="AutoSta_LX"   # grub-legacy
649   [[ -z ${KRNINITRD} ]] && KRNINITRD="initrd"   else
650     ### grubconf schreiben
651     source ${INSTALLPATH}/boot/kernelversion
652    
653   echo "default 0" > ${INSTALLPATH}/boot/grub/grub.conf || die   #for alx only
654   echo "timeout 0" >> ${INSTALLPATH}/boot/grub/grub.conf ||die   if [ -e ${INSTALLPATH}/etc/alx_version ]
655     then
656     OLD_ALXVER="${ALXVER}"
657     source ${INSTALLPATH}/etc/alx_version
658     KRNVER="ALX-${ALXVER}"
659     ALXVER="${OLD_ALXVER}"
660     fi
661    
662   echo -e "\ntitle=${KRNVER}" >> ${INSTALLPATH}/boot/grub/grub.conf || die   [[ -z ${KRNVER} ]] && KRNVER="AutoSta_LX"
663   echo "root (hd0,0)" >> ${INSTALLPATH}/boot/grub/grub.conf || die   [[ -z ${KRNINITRD} ]] && KRNINITRD="initrd"
664     [[ -z ${KRNIMG} ]] && KRNIMG="vmlinuz"
665   echo "kernel /boot/vmlinuz root=${ROOTHDD} quiet" >> ${INSTALLPATH}/boot/grub/grub.conf || die  
666   echo "initrd /boot/initrd" >> ${INSTALLPATH}/boot/grub/grub.conf || die   # uuid support
667     if is_uuid_supported
668   # bootsector schreiben chrooted schreiben (lfs/magellan)   then
669   cat > ${INSTALLPATH}/root/.bashrc << CHROOTEOF   my_roothdd="UUID=$(get_uuid ${ROOTHDD})"
670     else
671     my_roothdd="${ROOTHDD}"
672     fi
673    
674     : > ${grubconf} || die
675     echo "default 0" >> ${grubconf} || die
676     echo "timeout 3" >> ${grubconf} || die
677     # using current root password
678     echo "password --md5 $(cat ${INSTALLPATH}/etc/shadow | grep root | cut -d: -f2)"  >> ${grubconf} || die
679    
680     echo  >> ${grubconf} || die
681     echo "# normal boot" >> ${grubconf} || die
682     echo "title ${KRNVER}" >> ${grubconf} || die
683     echo "root (hd0,0)" >> ${grubconf} || die
684     echo "kernel /boot/${KRNIMG} root=${my_roothdd} ${KERNELOPTS} ${GRUBLEGACYOPTS}" >> ${grubconf} || die
685     if is_initrd_supported
686     then
687     echo "initrd /boot/${KRNINITRD}" >> ${grubconf} || die
688     fi
689    
690     echo >> ${grubconf} || die
691     echo "# admin boot" >> ${grubconf} || die
692     echo "title ${KRNVER} - Re-run hardware-detection" >> ${grubconf} || die
693     echo "lock"  >> ${grubconf} || die
694     echo "root (hd0,0)" >> ${grubconf} || die
695     echo "kernel /boot/${KRNIMG} root=${my_roothdd} ${KERNELOPTS} ${GRUBLEGACYOPTS} hardware-auto-detection" >> ${grubconf} || die
696     if is_initrd_supported
697     then
698     echo "initrd /boot/${KRNINITRD}" >> ${grubconf} || die
699     fi
700    
701     echo >> ${grubconf} || die
702     echo "title ${KRNVER} - Reset *all* local settings" >> ${grubconf} || die
703     echo "lock"  >> ${grubconf} || die
704     echo "root (hd0,0)" >> ${grubconf} || die
705     echo "kernel /boot/${KRNIMG} root=${my_roothdd} ${KERNELOPTS} ${GRUBLEGACYOPTS} alx-reset-settings" >> ${grubconf} || die
706     if is_initrd_supported
707     then
708     echo "initrd /boot/${KRNINITRD}" >> ${grubconf} || die
709     fi
710    
711     # bootsector schreiben chrooted schreiben (lfs/magellan)
712     cat > ${INSTALLPATH}/root/.installrc << CHROOTEOF
713  /usr/sbin/grub --no-floppy --batch << "EOF" 1> /dev/null 2> /dev/null  /usr/sbin/grub --no-floppy --batch << "EOF" 1> /dev/null 2> /dev/null
714  root (hd0,0)  root (hd0,0)
715  setup (hd0)  setup (hd0)
716  quit  quit
717  EOF  EOF
718  echo "MODULES=\"ext3 amd74xx piix sis5513 via82cxxx\"" > /etc/conf.d/mkinitrd  exit 0
719  mkinitrd -f /boot/$(readlink /boot/initrd) $(readlink /boot/vmlinuz | sed "s:kernel-::g")  CHROOTEOF
720     fi
721    
722     ## enters chroot
723     mount -t proc proc ${INSTALLPATH}/proc
724     mount -t sysfs sysfs ${INSTALLPATH}/sys
725     mount -o bind /dev ${INSTALLPATH}/dev
726     chroot ${INSTALLPATH} /bin/bash --rcfile /root/.installrc -i
727     umount ${INSTALLPATH}/proc
728     umount ${INSTALLPATH}/sys
729     umount ${INSTALLPATH}/dev
730     rm ${INSTALLPATH}/root/.installrc
731    }
732    
733    is_initrd_supported()
734    {
735     # only generate initrds if the cmd exists
736     [[ -x ${INSTALLPATH}/sbin/mkinitrd ]] && return 0
737     return 1
738    }
739    
740    install_initrd_chroot()
741    {
742     # only generate initrds if the cmd exists
743     is_initrd_supported || return 0
744    
745     DISKMODS="sd_mod"
746     OLDPATAMODS="amd74xx piix sis5513 via82cxxx"
747     PATAMODS="ata_piix pata_amd pata_mpiix pata_oldpiix pata_sis pata_via"
748     SATAMODS="sata_via sata_sis sata_nv"
749     DRMMODS="i915 mga nouveau r128 radeon savage sis tdfx ttm via"
750     case ${SPECIALDEVICE} in
751     zotac_intel) FBMODS=""; DRMMODS="i915" ;;
752     zotac_nvidia) FBMODS=""; DRMMODS="nouveau" ;;
753     rangee) FBMODS="" ;; ## fallback to vesafb, viafb does not run on all CLE266 boards
754     maxdata) FBMODS="i810fb" ;; ## check for maxdata / i810/ i815 Chipsets and disable KMS and use i810fb frambuffer
755     *) FBMODS="uvesafb" ;;
756     esac
757    
758     # install an appropriate uvesafb.conf
759     install -d ${INSTALLPATH}/etc/modprobe.d || die
760     echo "options uvesafb mode_option=1024x768-32@60 scroll=ywrap" > ${INSTALLPATH}/etc/modprobe.d/uvesafb.conf || die
761    
762     # install an appropriate viafb.conf
763     echo "options viafb viafb_mode=1024x768 viafb_refresh=60" > ${INSTALLPATH}/etc/modprobe.d/viafb.conf || die
764    
765     # install an appropriate i810fb.conf
766     echo "options i810fb xres=1024 yres=768 bpp=16 mtrr=1 hsync1=30 hsync2=62 vsync1=30 vsync2=60"  > ${INSTALLPATH}/etc/modprobe.d/i810fb.conf || die
767    
768     cat > ${INSTALLPATH}/root/.installrc << CHROOTEOF
769    echo "MODULES=\"${FORMAT_FILESYSTEM} ${DISKMODS} ${OLDATAMODS} ${PATAMODS} ${SATAMODS} ${DRMMODS} ${FBMODS}\"" > /etc/conf.d/mkinitrd
770    mkinitrd -f /boot/$(readlink /boot/initrd) $(readlink /boot/vmlinuz | sed "s:kernel-::g") > /dev/null
771  exit 0  exit 0
772  CHROOTEOF  CHROOTEOF
773    
# Line 427  CHROOTEOF Line 775  CHROOTEOF
775   mount -t proc proc ${INSTALLPATH}/proc   mount -t proc proc ${INSTALLPATH}/proc
776   mount -t sysfs sysfs ${INSTALLPATH}/sys   mount -t sysfs sysfs ${INSTALLPATH}/sys
777   mount -o bind /dev ${INSTALLPATH}/dev   mount -o bind /dev ${INSTALLPATH}/dev
778   chroot ${INSTALLPATH} /bin/bash --rcfile /root/.bashrc -i   chroot ${INSTALLPATH} /bin/bash --rcfile /root/.installrc -i
779   umount ${INSTALLPATH}/proc   umount ${INSTALLPATH}/proc
780   umount ${INSTALLPATH}/sys   umount ${INSTALLPATH}/sys
781   umount ${INSTALLPATH}/dev   umount ${INSTALLPATH}/dev
782   rm ${INSTALLPATH}/root/.bashrc   rm ${INSTALLPATH}/root/.installrc
783    }
784    
785    is_uuid_supported()
786    {
787     if [[ -x $(which busybox.mkinitrd &> /dev/null) ]]
788     then
789     # only detect uuids if supported
790     if [[ ! -z $(busybox.mkinitrd | grep blkid) ]]
791     then
792     return 0
793     fi
794     fi
795    
796     return 1
797    }
798    
799    get_uuid()
800    {
801     local UUID
802     local SEC_TYPE
803     local TYPE
804    
805     local dev="$1"
806     [[ -z ${dev} ]] && die "no dev given"
807    
808     # check if given device is already an UUID
809     if [[ ${dev/UUID=/}x != ${dev}x ]]
810     then
811     eval "${dev}"
812     else
813     eval $(busybox.mkinitrd blkid ${dev} | grep "${dev}:" | sed 's/.*:\ //')
814     fi
815     echo "${UUID}"
816  }  }
817    
818  install_system_settings()  install_system_settings()
819  {  {
820   # schreibe fstab   # schreibe fstab
821   echo -e "${BOOTHDD}\t/boot\text3\tnoatime,noauto\t1 1" > ${INSTALLPATH}/etc/fstab || die   if is_uuid_supported
822   echo -e "${ROOTHDD}\t/\text3\tnoatime\t0 0" >> ${INSTALLPATH}/etc/fstab || die   then
823   echo -e "${SWAPHDD}\tswap\tswap\tpri=1\t0 0" >> ${INSTALLPATH}/etc/fstab || die   echo -e "UUID=$(get_uuid ${BOOTHDD})\t/boot\t${FORMAT_FILESYSTEM}\tnoatime,noauto\t1 1" > ${INSTALLPATH}/etc/fstab || die
824     echo -e "UUID=$(get_uuid ${ROOTHDD})\t/\t${FORMAT_FILESYSTEM}\tnoatime\t0 0" >> ${INSTALLPATH}/etc/fstab || die
825     else
826     echo -e "${BOOTHDD}\t/boot\t${FORMAT_FILESYSTEM}\tnoatime,noauto\t1 1" > ${INSTALLPATH}/etc/fstab || die
827     echo -e "${ROOTHDD}\t/\t${FORMAT_FILESYSTEM}\tnoatime\t0 0" >> ${INSTALLPATH}/etc/fstab || die
828     fi
829     # not needed busybox loads all with swapon -a, even if not mentioned in fstab
830     #echo -e "UUID='$(get_uuid ${SWAPHDD})'\tswap\tswap\tpri=1\t0 0" >> ${INSTALLPATH}/etc/fstab || die
831   echo -e "proc\t/proc\tproc\tdefaults\t0 0" >> ${INSTALLPATH}/etc/fstab || die   echo -e "proc\t/proc\tproc\tdefaults\t0 0" >> ${INSTALLPATH}/etc/fstab || die
832   echo -e "shm\t/dev/shm\ttmpfs\tdefaults\t0 0" >> ${INSTALLPATH}/etc/fstab || die   echo -e "shm\t/dev/shm\ttmpfs\tdefaults\t0 0" >> ${INSTALLPATH}/etc/fstab || die
833    
834     # install network config skeleton
835     install -m0644 ${INSTALLPATH}/etc/alxconfig-ng/skel/net/net.eth0 ${INSTALLPATH}/etc/conf.d/ || die
836    
837     # intel framebufer quirk
838     if [[ -e /proc/fb ]]
839     then
840     if [[ ! -z $(grep 'inteldrmfb' /proc/fb) ]]
841     then
842     fbdev=$(grep 'inteldrmfb' /proc/fb | sed 's:\([0-9]\).*:\1:')
843     if [[ ${fbdev} != 0 ]]
844     then
845     sed -i "s:^\(SPLASH_DEV=\).*:\1\"/dev/fb${fbdev}\":" ${INSTALLPATH}/etc/splash/splash.conf || die
846     fi
847     fi
848     fi
849  }  }
850    
851  install_system_settings_flash()  install_system_settings_flash()
852  {  {
853   # schreibe fstab   # schreibe fstab
854   echo -e "${ROOTHDD}\t/\text3\tnoatime\t0 0" > ${INSTALLPATH}/etc/fstab || die   if is_uuid_supported
855     then
856     echo -e "UUID=$(get_uuid ${ROOTHDD})\t/\t${FORMAT_FILESYSTEM}\tnoatime\t0 0" > ${INSTALLPATH}/etc/fstab || die
857     else
858     echo -e "${ROOTHDD}\t/\t${FORMAT_FILESYSTEM}\tnoatime\t0 0" > ${INSTALLPATH}/etc/fstab || die
859     fi
860   echo -e "proc\t/proc\tproc\tdefaults\t0 0" >> ${INSTALLPATH}/etc/fstab || die   echo -e "proc\t/proc\tproc\tdefaults\t0 0" >> ${INSTALLPATH}/etc/fstab || die
861   echo -e "shm\t/dev/shm\ttmpfs\tdefaults\t0 0" >> ${INSTALLPATH}/etc/fstab || die   echo -e "shm\t/dev/shm\ttmpfs\tdefaults\t0 0" >> ${INSTALLPATH}/etc/fstab || die
862  }  }
# Line 477  install_do_reboot() Line 886  install_do_reboot()
886    
887  run_install_normal()  run_install_normal()
888  {  {
889   dialog_setup_hdd_found_manuell   dialog_hardware_detection
890    
891   dialog_setup_hdd_partitions_manuell   dialog_setup_hdd_partitions_manuell
892   dialog_setup_hdd_format   dialog_setup_hdd_format
# Line 485  run_install_normal() Line 894  run_install_normal()
894   install_mount_rootfs   install_mount_rootfs
895   (install_system_image > /tmp/install.log) 2> /tmp/install_errors.log | dialog_install_meter | dialog_install_system_image   (install_system_image > /tmp/install.log) 2> /tmp/install_errors.log | dialog_install_meter | dialog_install_system_image
896    
  dialog_install_bootsector  
  install_bootsector_chroot  
   
897   dialog_install_settings   dialog_install_settings
898   sleep 1   sleep 1
899   install_system_settings   install_system_settings
900     install_initrd_chroot
901    
902     dialog_install_bootsector
903     install_bootsector_chroot
904    
905   install_umount_rootfs   install_umount_rootfs
906   dialog_install_successful   dialog_install_successful
907  }  }
908    
909  run_install_flash()  run_install_flash()
910  {  {
911   dialog_setup_hdd_found_manuell   dialog_hardware_detection
912    
913   dialog_setup_hdd_partitions_manuell_flash   dialog_setup_hdd_partitions_manuell_flash
914   dialog_setup_hdd_format   dialog_setup_hdd_format
# Line 505  run_install_flash() Line 916  run_install_flash()
916   install_mount_rootfs_flash   install_mount_rootfs_flash
917   (install_system_image > /tmp/install.log) 2> /tmp/install_errors.log | dialog_install_meter | dialog_install_system_image   (install_system_image > /tmp/install.log) 2> /tmp/install_errors.log | dialog_install_meter | dialog_install_system_image
918    
919     dialog_install_settings
920     sleep 1
921     install_system_settings_flash
922     install_initrd_chroot
923    
924   dialog_install_bootsector   dialog_install_bootsector
925   install_bootsector_chroot   install_bootsector_chroot
926    
927     install_umount_rootfs_flash
928     dialog_install_successful
929    }
930    
931    run_install_auto()
932    {
933     dialog_hardware_detection
934    
935     dialog_setup_hdd_partitions_auto
936     dialog_setup_hdd_format
937     setup_hdd_format_flash > /dev/null
938     install_mount_rootfs_flash
939     (install_system_image > /tmp/install.log) 2> /tmp/install_errors.log | dialog_install_meter | dialog_install_system_image
940    
941   dialog_install_settings   dialog_install_settings
942   sleep 1   sleep 1
943   install_system_settings_flash   install_system_settings_flash
944     install_initrd_chroot
945    
946     dialog_install_bootsector
947     install_bootsector_chroot
948    
949   install_umount_rootfs_flash   install_umount_rootfs_flash
950   dialog_install_successful   dialog_install_successful
951  }  }

Legend:
Removed from v.527  
changed lines
  Added in v.4847