Por que a inicialização está sendo interrompida no prompt initramfs?

1

Estou executando o Debian Xfce na caixa virtual (Sistema Operacional Host: Ubuntu 12.04 LTS). No Debian eu baixei o código-fonte do Linux kernel-2.6.32.61 de link e eu configurei e compilei com sucesso. Eu segui estes passos (com su):

  1. defconfig
  2. fazer
  3. faça módulos
  4. crie install_modules

Depois disso eu editei o arquivo /etc/grub.d/40_custom e executei o grub-mkconfig . Então eu coloquei os arquivos config, initrd.img, System.map, vmlinuz na pasta / boot / e assim instalei o novo kernel no mesmo disco e na mesma partição onde o kernel do Debian foi instalado na caixa virtual. Então eu reiniciei a caixa virtual e inicializei a partir do kernel construído, mas o processo de inicialização se inclinou dando-me um prompt como mostrado na imagem:


(desculpe,eunãotenhopontosdereputaçãosuficientesparapostarumaimagem).)

/boot/grub/grub.cfgdoDebian:

##DONOTEDITTHISFILE##Itisautomaticallygeneratedbygrub-mkconfigusingtemplates#from/etc/grub.dandsettingsfrom/etc/default/grub####BEGIN/etc/grub.d/00_header###if[-s$prefix/grubenv];thenload_envfisetdefault="0"
if [ "${prev_saved_entry}" ]; then
  set saved_entry="${prev_saved_entry}"
  save_env saved_entry
  set prev_saved_entry=
  save_env prev_saved_entry
  set boot_once=true
fi

function savedefault {
  if [ -z "${boot_once}" ]; then
    saved_entry="${chosen}"
    save_env saved_entry
  fi
}

function load_video {
  insmod vbe
  insmod vga
  insmod video_bochs
  insmod video_cirrus
}

insmod part_msdos
insmod ext2
set root='(hd0,msdos5)'
search --no-floppy --fs-uuid --set=root 33cee34f-8bec-4f6a-963f-d26bdffda28c
if loadfont /usr/share/grub/unicode.pf2 ; then
  set gfxmode=640x480
  load_video
  insmod gfxterm
  insmod part_msdos
  insmod ext2
  set root='(hd0,msdos5)'
  search --no-floppy --fs-uuid --set=root 33cee34f-8bec-4f6a-963f-d26bdffda28c
  set locale_dir=($root)/boot/grub/locale
  set lang=en_US
  insmod gettext
fi
terminal_output gfxterm
set timeout=5
### END /etc/grub.d/00_header ###

### BEGIN /etc/grub.d/05_debian_theme ###
insmod part_msdos
insmod ext2
set root='(hd0,msdos5)'
search --no-floppy --fs-uuid --set=root 33cee34f-8bec-4f6a-963f-d26bdffda28c
insmod png
if background_image /usr/share/images/desktop-base/joy-grub.png; then
  set color_normal=white/black
  set color_highlight=black/white
else
  set menu_color_normal=cyan/blue
  set menu_color_highlight=white/blue
fi
### END /etc/grub.d/05_debian_theme ###

### BEGIN /etc/grub.d/10_linux ###
menuentry 'Debian GNU/Linux, with Linux 3.2.0-4-686-pae' --class debian --class gnu-linux --class gnu --class os {
    load_video
    insmod gzio
    insmod part_msdos
    insmod ext2
    set root='(hd0,msdos5)'
    search --no-floppy --fs-uuid --set=root 33cee34f-8bec-4f6a-963f-d26bdffda28c
    echo    'Loading Linux 3.2.0-4-686-pae ...'
    linux   /boot/vmlinuz-3.2.0-4-686-pae root=UUID=33cee34f-8bec-4f6a-963f-d26bdffda28c ro  quiet
    echo    'Loading initial ramdisk ...'
    initrd  /boot/initrd.img-3.2.0-4-686-pae
}
menuentry 'Debian GNU/Linux, with Linux 3.2.0-4-686-pae (recovery mode)' --class debian --class gnu-linux --class gnu --class os {
    load_video
    insmod gzio
    insmod part_msdos
    insmod ext2
    set root='(hd0,msdos5)'
    search --no-floppy --fs-uuid --set=root 33cee34f-8bec-4f6a-963f-d26bdffda28c
    echo    'Loading Linux 3.2.0-4-686-pae ...'
    linux   /boot/vmlinuz-3.2.0-4-686-pae root=UUID=33cee34f-8bec-4f6a-963f-d26bdffda28c ro single 
    echo    'Loading initial ramdisk ...'
    initrd  /boot/initrd.img-3.2.0-4-686-pae
}
### END /etc/grub.d/10_linux ###

### BEGIN /etc/grub.d/20_linux_xen ###
### END /etc/grub.d/20_linux_xen ###

### BEGIN /etc/grub.d/30_os-prober ###
### END /etc/grub.d/30_os-prober ###

### BEGIN /etc/grub.d/40_custom ###
# This file provides an easy way to add custom menu entries.  Simply type the
# menu entries you want to add after this comment.  Be careful not to change
# the 'exec tail' line above.

menuentry 'Saurabh GNU/Linux, with Linux 2.6.32.61' --class gnu-linux --class gnu --class os{
    load_video
    insmod gzio
    insmod part_msdos
    insmod ext2
    set root='(hd0,msdos5)'
    search --no-floppy  --fs-uuid --set=root 33cee34f-8bec-4f6a-963f-d26bdffda28c
    echo 'Loading Saurabh Linux 2.6.32.61... '
    linux /boot/vmlinuz-2.6.32.61 root=/dev/sda5  ro quiet
    echo 'Loading initial ramdisk ...'
    initrd /boot/initrd.img-2.6.32.61
}
### END /etc/grub.d/40_custom ###

### BEGIN /etc/grub.d/41_custom ###
if [ -f  $prefix/custom.cfg ]; then
  source $prefix/custom.cfg;
fi
### END /etc/grub.d/41_custom ###

Arquivo 40_personalizado:

#!/bin/sh
exec tail -n +3 $0
# This file provides an easy way to add custom menu entries.  Simply type the
# menu entries you want to add after this comment.  Be careful not to change
# the 'exec tail' line above.

menuentry 'Saurabh GNU/Linux, with Linux 2.6.32.61' --class gnu-linux --class gnu --class os{
    load_video
    insmod gzio
    insmod part_msdos
    insmod ext2
    set root='(hd0,msdos5)'
    search --no-floppy  --fs-uuid --set=root 33cee34f-8bec-4f6a-963f-d26bdffda28c
    echo 'Loading Saurabh Linux 2.6.32.61... '
    linux /boot/vmlinuz-2.6.32.61 root=/dev/sda5  ro quiet
    echo 'Loading initial ramdisk ...'
    initrd /boot/initrd.img-2.6.32.61
}

/ etc / fstab do Debian

# <file system> <mount point>   <type>  <options>       <dump>  <pass>
# / was on /dev/sda5 during installation
UUID=33cee34f-8bec-4f6a-963f-d26bdffda28c /               ext4    errors=remount-ro 0       1
# swap was on /dev/sda1 during installation
UUID=faa1c54b-4e9f-4af6-9b1e-8fdceffb321f none            swap    sw              0       0
/dev/sr0        /media/cdrom0   udf,iso9660 user,noauto     0       0

(estou fazendo todos esses experimentos apenas na caixa virtual)
Alguém me ajude, por que estou recebendo esse erro?

    
por nitin 11.01.2014 / 17:47

1 resposta

0

Talvez isso fosse óbvio, mas o problema não é que você estava caindo no BusyBox (initramfs). O problema são as 10 linhas acima desse prompt, nas quais você vê quase todas as tentativas de montar os ativos do kernel falhando um após o outro.

Provavelmente, um dos seus set root='(hd0,msdos5)' or - set = root 33cee34f-8bec-4f6a-963f-d26bdffda28c 'está errado.

Quando o grub olhou para o / boot, ele encontrou o kernel, mas quando ele carregou o kernel, uma de suas declarações root mudou o local de / boot, então agora o kernel não pode monte o que ele precisa do initrd (ou isso ou o seu initrd foi compilado incorretamente para combinar com o seu kernel).

Seu kernel está carregando bem, eu acredito, mas ele não consegue encontrar o resto do userspace, então ele volta ao grub.

Tente ser menos detalhado com os UIDs de sua unidade, veja até onde os padrões chegarão até você. Considerando executar o mkinitrd para seu kernel novamente.

    
por 03.08.2014 / 04:50