PCにUSB3ドライブを接続すると、「Welcome to grub」というメッセージでコンピュータがハングします。

PCにUSB3ドライブを接続すると、「Welcome to grub」というメッセージでコンピュータがハングします。


ext4形式のSeagate 2TB USB2ハードドライブがあります。システムに接続して起動すると、PCは「Welcome to grub」で停止します。 USBドライブを接続せずに再起動すると、システムは正常に起動します。その後、ドライブを接続して使用できます。

Debian GNU/Linux jessie/sid最新のアップデートを使用しています。
Ubuntu livecds / usbsが正常に起動します。

lsusb(外付けドライブ):

Bus 001 Device 006: ID 0bc2:3332 Seagate RSS LLC Expansion

grub-pcバージョン:2.00-14

マザーボードにはUSB2ポート(Intel H55TC)のみがあり、BIOSは最新の状態です(以前のファームウェアと新しいファームウェアの両方に同じ問題があります)。

原因は何ですか?
(アイデアが足りないので、テスト可能な推測を歓迎します)。

メモ:USBドライブが原因であることを理解するまで約10回起動し、最終的には正常に起動し始めました。

これは私のgrub.cfgです。

#
# DO NOT EDIT THIS FILE
#
# It is automatically generated by grub-mkconfig using templates
# from /etc/grub.d and settings from /etc/default/grub
#

### BEGIN /etc/grub.d/00_header ###
if [ -s $prefix/grubenv ]; then
load_env
fi
set default="0"

if [ x"${feature_menuentry_id}" = xy ]; then
menuentry_id_option="--id"
else
menuentry_id_option=""
fi

export menuentry_id_option

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 {
if [ x$feature_all_video_module = xy ]; then
    insmod all_video
else
    insmod efi_gop
    insmod efi_uga
    insmod ieee1275_fb
    insmod vbe
    insmod vga
    insmod video_bochs
    insmod video_cirrus
fi
}

terminal_input console
terminal_output console
set timeout=5
### END /etc/grub.d/00_header ###

### BEGIN /etc/grub.d/05_debian_theme ###
set menu_color_normal=cyan/blue
set menu_color_highlight=white/blue
### END /etc/grub.d/05_debian_theme ###

### BEGIN /etc/grub.d/10_linux ###
menuentry 'Debian GNU/Linux' --class debian --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-simple-2f0165f3-2087-4157-b1e6-f707a995827b' {
        load_video
        insmod gzio
        insmod part_msdos
        insmod part_msdos
        insmod diskfilter
        insmod mdraid09
        insmod ext2
        set root='mduuid/019e28032b26f1e0e368bf24bd0fce41'
        if [ x$feature_platform_search_hint = xy ]; then
        search --no-floppy --fs-uuid --set=root --hint='mduuid/019e28032b26f1e0e368bf24bd0fce41'  2f0165f3-2087-4157-b1e6-f707a995827b
        else
        search --no-floppy --fs-uuid --set=root 2f0165f3-2087-4157-b1e6-f707a995827b
        fi
        echo    'Loading Linux 3.9-1-686-pae ...'
        linux   /boot/vmlinuz-3.9-1-686-pae root=UUID=2f0165f3-2087-4157-b1e6-f707a995827b ro  hdd=noprobe
        echo    'Loading initial ramdisk ...'
        initrd  /boot/initrd.img-3.9-1-686-pae
}
submenu 'Advanced options for Debian GNU/Linux' $menuentry_id_option 'gnulinux-advanced-2f0165f3-2087-4157-b1e6-f707a995827b' {
        menuentry 'Debian GNU/Linux, with Linux 3.9-1-686-pae' --class debian --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-3.9-1-686-pae-advanced-2f0165f3-2087-4157-b1e6-f707a995827b' {
                load_video
                insmod gzio
                insmod part_msdos
                insmod part_msdos
                insmod diskfilter
                insmod mdraid09
                insmod ext2
                set root='mduuid/019e28032b26f1e0e368bf24bd0fce41'
                if [ x$feature_platform_search_hint = xy ]; then
                search --no-floppy --fs-uuid --set=root --hint='mduuid/019e28032b26f1e0e368bf24bd0fce41'  2f0165f3-2087-4157-b1e6-f707a995827b
                else
                search --no-floppy --fs-uuid --set=root 2f0165f3-2087-4157-b1e6-f707a995827b
                fi
                echo    'Loading Linux 3.9-1-686-pae ...'
                linux   /boot/vmlinuz-3.9-1-686-pae root=UUID=2f0165f3-2087-4157-b1e6-f707a995827b ro  hdd=noprobe
                echo    'Loading initial ramdisk ...'
                initrd  /boot/initrd.img-3.9-1-686-pae
        }
        menuentry 'Debian GNU/Linux, with Linux 3.9-1-686-pae (recovery mode)' --class debian --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-3.9-1-686-pae-recovery-2f0165f3-2087-4157-b1e6-f707a995827b' {
                load_video
                insmod gzio
                insmod part_msdos
                insmod part_msdos
                insmod diskfilter
                insmod mdraid09
                insmod ext2
                set root='mduuid/019e28032b26f1e0e368bf24bd0fce41'
                if [ x$feature_platform_search_hint = xy ]; then
                search --no-floppy --fs-uuid --set=root --hint='mduuid/019e28032b26f1e0e368bf24bd0fce41'  2f0165f3-2087-4157-b1e6-f707a995827b
                else
                search --no-floppy --fs-uuid --set=root 2f0165f3-2087-4157-b1e6-f707a995827b
                fi
                echo    'Loading Linux 3.9-1-686-pae ...'
                linux   /boot/vmlinuz-3.9-1-686-pae root=UUID=2f0165f3-2087-4157-b1e6-f707a995827b ro single 
                echo    'Loading initial ramdisk ...'
                initrd  /boot/initrd.img-3.9-1-686-pae
        }
        menuentry 'Debian GNU/Linux, with Linux 3.2.0-4-686-pae' --class debian --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-3.2.0-4-686-pae-advanced-2f0165f3-2087-4157-b1e6-f707a995827b' {
                load_video
                insmod gzio
                insmod part_msdos
                insmod part_msdos
                insmod diskfilter
                insmod mdraid09
                insmod ext2
                set root='mduuid/019e28032b26f1e0e368bf24bd0fce41'
                if [ x$feature_platform_search_hint = xy ]; then
                search --no-floppy --fs-uuid --set=root --hint='mduuid/019e28032b26f1e0e368bf24bd0fce41'  2f0165f3-2087-4157-b1e6-f707a995827b
                else
                search --no-floppy --fs-uuid --set=root 2f0165f3-2087-4157-b1e6-f707a995827b
                fi
                echo    'Loading Linux 3.2.0-4-686-pae ...'
                linux   /boot/vmlinuz-3.2.0-4-686-pae root=UUID=2f0165f3-2087-4157-b1e6-f707a995827b ro  hdd=noprobe
                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 $menuentry_id_option 'gnulinux-3.2.0-4-686-pae-recovery-2f0165f3-2087-4157-b1e6-f707a995827b' {
                load_video
                insmod gzio
                insmod part_msdos
                insmod part_msdos
                insmod diskfilter
                insmod mdraid09
                insmod ext2
                set root='mduuid/019e28032b26f1e0e368bf24bd0fce41'
                if [ x$feature_platform_search_hint = xy ]; then
                search --no-floppy --fs-uuid --set=root --hint='mduuid/019e28032b26f1e0e368bf24bd0fce41'  2f0165f3-2087-4157-b1e6-f707a995827b
                else
                search --no-floppy --fs-uuid --set=root 2f0165f3-2087-4157-b1e6-f707a995827b
                fi
                echo    'Loading Linux 3.2.0-4-686-pae ...'
                linux   /boot/vmlinuz-3.2.0-4-686-pae root=UUID=2f0165f3-2087-4157-b1e6-f707a995827b ro single 
                echo    'Loading initial ramdisk ...'
                initrd  /boot/initrd.img-3.2.0-4-686-pae
        }
        menuentry 'Debian GNU/Linux, with Linux 3.2.0-3-686-pae' --class debian --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-3.2.0-3-686-pae-advanced-2f0165f3-2087-4157-b1e6-f707a995827b' {
                load_video
                insmod gzio
                insmod part_msdos
                insmod part_msdos
                insmod diskfilter
                insmod mdraid09
                insmod ext2
                set root='mduuid/019e28032b26f1e0e368bf24bd0fce41'
                if [ x$feature_platform_search_hint = xy ]; then
                search --no-floppy --fs-uuid --set=root --hint='mduuid/019e28032b26f1e0e368bf24bd0fce41'  2f0165f3-2087-4157-b1e6-f707a995827b
                else
                search --no-floppy --fs-uuid --set=root 2f0165f3-2087-4157-b1e6-f707a995827b
                fi
                echo    'Loading Linux 3.2.0-3-686-pae ...'
                linux   /boot/vmlinuz-3.2.0-3-686-pae root=UUID=2f0165f3-2087-4157-b1e6-f707a995827b ro  hdd=noprobe
                echo    'Loading initial ramdisk ...'
                initrd  /boot/initrd.img-3.2.0-3-686-pae
        }
        menuentry 'Debian GNU/Linux, with Linux 3.2.0-3-686-pae (recovery mode)' --class debian --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-3.2.0-3-686-pae-recovery-2f0165f3-2087-4157-b1e6-f707a995827b' {
                load_video
                insmod gzio
                insmod part_msdos
                insmod part_msdos
                insmod diskfilter
                insmod mdraid09
                insmod ext2
                set root='mduuid/019e28032b26f1e0e368bf24bd0fce41'
                if [ x$feature_platform_search_hint = xy ]; then
                search --no-floppy --fs-uuid --set=root --hint='mduuid/019e28032b26f1e0e368bf24bd0fce41'  2f0165f3-2087-4157-b1e6-f707a995827b
                else
                search --no-floppy --fs-uuid --set=root 2f0165f3-2087-4157-b1e6-f707a995827b
                fi
                echo    'Loading Linux 3.2.0-3-686-pae ...'
                linux   /boot/vmlinuz-3.2.0-3-686-pae root=UUID=2f0165f3-2087-4157-b1e6-f707a995827b ro single 
                echo    'Loading initial ramdisk ...'
                initrd  /boot/initrd.img-3.2.0-3-686-pae
        }
        menuentry 'Debian GNU/Linux, with Linux 3.2.0-2-686-pae' --class debian --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-3.2.0-2-686-pae-advanced-2f0165f3-2087-4157-b1e6-f707a995827b' {
                load_video
                insmod gzio
                insmod part_msdos
                insmod part_msdos
                insmod diskfilter
                insmod mdraid09
                insmod ext2
                set root='mduuid/019e28032b26f1e0e368bf24bd0fce41'
                if [ x$feature_platform_search_hint = xy ]; then
                search --no-floppy --fs-uuid --set=root --hint='mduuid/019e28032b26f1e0e368bf24bd0fce41'  2f0165f3-2087-4157-b1e6-f707a995827b
                else
                search --no-floppy --fs-uuid --set=root 2f0165f3-2087-4157-b1e6-f707a995827b
                fi
                echo    'Loading Linux 3.2.0-2-686-pae ...'
                linux   /boot/vmlinuz-3.2.0-2-686-pae root=UUID=2f0165f3-2087-4157-b1e6-f707a995827b ro  hdd=noprobe
                echo    'Loading initial ramdisk ...'
                initrd  /boot/initrd.img-3.2.0-2-686-pae
        }
        menuentry 'Debian GNU/Linux, with Linux 3.2.0-2-686-pae (recovery mode)' --class debian --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-3.2.0-2-686-pae-recovery-2f0165f3-2087-4157-b1e6-f707a995827b' {
                load_video
                insmod gzio
                insmod part_msdos
                insmod part_msdos
                insmod diskfilter
                insmod mdraid09
                insmod ext2
                set root='mduuid/019e28032b26f1e0e368bf24bd0fce41'
                if [ x$feature_platform_search_hint = xy ]; then
                search --no-floppy --fs-uuid --set=root --hint='mduuid/019e28032b26f1e0e368bf24bd0fce41'  2f0165f3-2087-4157-b1e6-f707a995827b
                else
                search --no-floppy --fs-uuid --set=root 2f0165f3-2087-4157-b1e6-f707a995827b
                fi
                echo    'Loading Linux 3.2.0-2-686-pae ...'
                linux   /boot/vmlinuz-3.2.0-2-686-pae root=UUID=2f0165f3-2087-4157-b1e6-f707a995827b ro single 
                echo    'Loading initial ramdisk ...'
                initrd  /boot/initrd.img-3.2.0-2-686-pae
        }
}

### END /etc/grub.d/10_linux ###

### BEGIN /etc/grub.d/20_ipxe ###
menuentry "Network boot (iPXE)" --users "" --class network {
        insmod part_msdos
        insmod part_msdos
        insmod diskfilter
        insmod mdraid09
        insmod ext2
        set root='mduuid/019e28032b26f1e0e368bf24bd0fce41'
        if [ x$feature_platform_search_hint = xy ]; then
        search --no-floppy --fs-uuid --set=root --hint='mduuid/019e28032b26f1e0e368bf24bd0fce41'  2f0165f3-2087-4157-b1e6-f707a995827b
        else
        search --no-floppy --fs-uuid --set=root 2f0165f3-2087-4157-b1e6-f707a995827b
        fi
        linux16 /boot/ipxe.lkrn
}
### END /etc/grub.d/20_ipxe ###

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

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

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

### BEGIN /etc/grub.d/20_memtest86+ ###
menuentry "Memory test (memtest86+)" {
        insmod part_msdos
        insmod part_msdos
        insmod diskfilter
        insmod mdraid09
        insmod ext2
        set root='mduuid/019e28032b26f1e0e368bf24bd0fce41'
        if [ x$feature_platform_search_hint = xy ]; then
        search --no-floppy --fs-uuid --set=root --hint='mduuid/019e28032b26f1e0e368bf24bd0fce41'  2f0165f3-2087-4157-b1e6-f707a995827b
        else
        search --no-floppy --fs-uuid --set=root 2f0165f3-2087-4157-b1e6-f707a995827b
        fi
        linux16 /boot/memtest86+.bin
}
menuentry "Memory test (memtest86+, serial console 115200)" {
        insmod part_msdos
        insmod part_msdos
        insmod diskfilter
        insmod mdraid09
        insmod ext2
        set root='mduuid/019e28032b26f1e0e368bf24bd0fce41'
        if [ x$feature_platform_search_hint = xy ]; then
        search --no-floppy --fs-uuid --set=root --hint='mduuid/019e28032b26f1e0e368bf24bd0fce41'  2f0165f3-2087-4157-b1e6-f707a995827b
        else
        search --no-floppy --fs-uuid --set=root 2f0165f3-2087-4157-b1e6-f707a995827b
        fi
        linux16 /boot/memtest86+.bin console=ttyS0,115200n8
}
menuentry "Memory test (memtest86+, experimental multiboot)" {
        insmod part_msdos
        insmod part_msdos
        insmod diskfilter
        insmod mdraid09
        insmod ext2
        set root='mduuid/019e28032b26f1e0e368bf24bd0fce41'
        if [ x$feature_platform_search_hint = xy ]; then
        search --no-floppy --fs-uuid --set=root --hint='mduuid/019e28032b26f1e0e368bf24bd0fce41'  2f0165f3-2087-4157-b1e6-f707a995827b
        else
        search --no-floppy --fs-uuid --set=root 2f0165f3-2087-4157-b1e6-f707a995827b
        fi
        multiboot       /boot/memtest86+_multiboot.bin
}
menuentry "Memory test (memtest86+, serial console 115200, experimental multiboot)" {
        insmod part_msdos
        insmod part_msdos
        insmod diskfilter
        insmod mdraid09
        insmod ext2
        set root='mduuid/019e28032b26f1e0e368bf24bd0fce41'
        if [ x$feature_platform_search_hint = xy ]; then
        search --no-floppy --fs-uuid --set=root --hint='mduuid/019e28032b26f1e0e368bf24bd0fce41'  2f0165f3-2087-4157-b1e6-f707a995827b
        else
        search --no-floppy --fs-uuid --set=root 2f0165f3-2087-4157-b1e6-f707a995827b
        fi
        multiboot       /boot/memtest86+_multiboot.bin console=ttyS0,115200n8
}
### END /etc/grub.d/20_memtest86+ ###

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

### BEGIN /etc/grub.d/30_uefi-firmware ###
### END /etc/grub.d/30_uefi-firmware ###

### 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.
### END /etc/grub.d/40_custom ###

### BEGIN /etc/grub.d/41_custom ###
if [ -f  ${config_directory}/custom.cfg ]; then
source ${config_directory}/custom.cfg
elif [ -z "${config_directory}" -a -f  $prefix/custom.cfg ]; then
source $prefix/custom.cfg;
fi
### END /etc/grub.d/41_custom ###

ベストアンサー1

起動順序

システムの起動順序は、システムがUSBドライブから起動するか、USBドライブにアクセスするように設定されているようです。システムのBIOSを再確認して、次のことが正しいことを確認します。

  1. ドライブの起動順序は、USBドライブがリストの一番下に来るようになっています。

別のコンピュータを試してみますか?

可能であれば、ドライブがインストールされた状態で別のコンピュータを起動している間に挿入されたドライブをテストし、特定のコンピュータとUSBの組み合わせのBIOS/ハードウェアの問題ではないことを確認します。

syslinux + BIOS + ext4の問題

私は次のタイトルでこれを見つけました:[解決済み] USBフラッシュドライブからの起動に関する問題ArchLinuxフォーラムで。このスレッドのコメント#8では、特定のBIOSがext4パーティションドライブを起動できないという問題について説明します。

抜粋

syslinux wikiエントリによると:

ext4形式のUSBドライブは最新のコンピュータから起動しますが、カーネルとinitrdを含む起動パーティションがfat16パーティションにないと、一部のコンピュータがクラッシュする可能性があります。

おすすめ記事