कस्टम रास्पियन छवि "कोई स्याही नहीं मिली" के साथ बूट करने में विफल रहती है


11

मैं एक कस्टम एसडी का निर्माण कर रहा हूँ डेसट्रॉस्ट्रैप का उपयोग करके रास्पियन की छवि, और परिणामस्वरूप छवि Kernel panic - not syncing: No init found.मेरे रास्पबेरी पाई और क्यूमू के नीचे दोनों के साथ बूट करने में विफल रहती है । मैं दोनों पर 2012-07-15-मट्ठा-रास्पियन छवि को सफलतापूर्वक बूट कर सकता हूं (हालांकि, पाई पर एक अलग एसडी कार्ड के साथ)। Qemu के लिए मैं XEC डिज़ाइन से कर्नेल का उपयोग कर रहा हूँ ।

% qemu-system-arm -M versatilepb -cpu arm1136 -kernel /usr/local/share/qemu/kernel-qemu -m 256 -drive file=raspbian3.img -serial stdio -append "dwc_otg.lpm_enable=0 console=ttyAMA0,115200 kgdboc=tty1,115200 console=tty1 root=/dev/sda2 elevator=noop"
...
EXT3-fs (sda2): error: couldn't mount because of unsupported optional features (240)
EXT2-fs (sda2): error: couldn't mount because of unsupported optional features (240)
EXT4-fs (sda2): mounted filesystem with ordered data mode. Opts: (null)
VFS: Mounted root (ext4 filesystem) readonly on device 8:2.
devtmpfs: mounted
Freeing init memory: 132K
Kernel panic - not syncing: No init found.  Try passing init= option to kernel. See Linux Documentation/init.txt for guidance.
[<c001a1cc>] (unwind_backtrace+0x0/0xf0) from [<c037ada0>] (panic+0x58/0x180)
[<c037ada0>] (panic+0x58/0x180) from [<c000857c>] (init_post+0x7c/0xcc)
[<c000857c>] (init_post+0x7c/0xcc) from [<c0475834>] (kernel_init+0xec/0x11c)

init=/bin/bashकर्नेल कमांड लाइन में जोड़ने से मदद नहीं मिलती:

Failed to execute /bin/bash.  Attempting defaults...
Kernel panic - not syncing: No init found.  Try passing init= option to kernel. See Linux Documentation/init.txt for guidance.

मेरी छवि में एक /bootऔर /विभाजन है, और सही चीजें सम्‍मिलित हैं:

% fdisk -l raspbian3.img

Disk raspbian3.img: 499 MB, 499999744 bytes
255 heads, 63 sectors/track, 60 cylinders, total 976562 sectors
Units = sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk identifier: 0x00000000

        Device Boot      Start         End      Blocks   Id  System
raspbian3.img1   *        1024      132095       65536    c  W95 FAT32 (LBA)
raspbian3.img2          132096      976561      422233   83  Linux

% mount | grep raspbian
/dev/mapper/loop1p2 on /tmp/raspbian type ext4 (rw)
/dev/mapper/loop1p1 on /tmp/raspbian/boot type vfat (rw)

% ls /tmp/raspbian/
bin  boot  dev  etc  home  lib  lost+found  media  mnt  opt  proc  root  run  sbin  selinux  srv  sys  tmp  usr  var
% ls /tmp/raspbian/boot
arm128_start.elf  arm224_start.elf  bootcode.bin  config.txt          kernel_emergency.img  loader.bin
arm192_start.elf  arm240_start.elf  cmdline.txt   kernel_cutdown.img  kernel.img            start.elf
% ls /tmp/raspbian/sbin/*init*
/tmp/raspbian/sbin/init
% ls /tmp/raspbian/bin/*sh*
/tmp/raspbian/bin/bash  /tmp/raspbian/bin/dash

/sbin/initमेरी छवि का SHA1 हैश 2012-07-15-मट्ठा-रास्पियन छवि से भी मेल खाता है।

यह मेरी स्क्रिप्ट है, और छवि को यहां डाउनलोड किया जा सकता है

#!/bin/sh
set -ev

# Author: Michael Gorven <http://michael.gorven.za.net/>

IMAGE="${1?Please specify output image name.}"
IMAGE_SIZE=500
BOOT_SIZE=64
ALIGN_SECTORS=1024
ALIGN_FSBLOCKS="$(($ALIGN_SECTORS*512/4096))"
MIRROR="http://mirrordirector.raspbian.org/raspbian"
PACKAGES="openssh-server sudo ntp fake-hwclock"

bootstrap() {
    if [ ! "$BUILDROOT" ]; then
        echo "BUILDROOT is empty, aborting."
        exit 1
    fi

    qemu-debootstrap --arch=armhf --keyring=~/.gnupg/pubring.gpg wheezy "$BUILDROOT" "$MIRROR"
}

configure() {
    if [ ! "$BUILDROOT" ]; then
        echo "BUILDROOT is empty, aborting."
        exit 1
    fi

    cat > "$BUILDROOT/etc/apt/sources.list" <<-EOF
    deb http://mirrordirector.raspbian.org/raspbian/ wheezy main contrib non-free rpi
    EOF

    cat > "$BUILDROOT/etc/apt/sources.list.d/mene.list" <<-EOF
    deb http://archive.mene.za.net/raspbian wheezy contrib
    EOF

    cat > "$BUILDROOT/etc/apt/sources.list.d/raspi.list" <<-EOF
    deb http://archive.raspberrypi.org/debian/ wheezy main untested
    EOF

    if [ "$http_proxy" ]; then
        cat > "$BUILDROOT/etc/apt/apt.conf.d/30proxy" <<-EOF
        Acquire::http::proxy "$http_proxy";
        EOF
    fi

    wget -O- http://archive.raspberrypi.org/debian/raspberrypi.gpg.key | chroot "$BUILDROOT" apt-key add -
    wget -O- http://archive.mene.za.net/key.asc | chroot "$BUILDROOT" apt-key add -

    chroot "$BUILDROOT" apt-get --yes update
    chroot "$BUILDROOT" apt-get --yes install raspberrypi-bootloader libraspberrypi-bin $PACKAGES
    chroot "$BUILDROOT" apt-get --yes clean

    cp "$BUILDROOT/boot/arm128_start.elf" "$BUILDROOT/boot/start.elf"

    cat > "$BUILDROOT/boot/config.txt" <<-EOF
    disable_overscan=1
    EOF

    cat > "$BUILDROOT/boot/cmdline.txt" <<-EOF
    dwc_otg.lpm_enable=0 console=ttyAMA0,115200 kgdboc=ttyAMA0,115200 console=tty1 root=/dev/mmcblk0p2 rootfstype=ext4 elevator=deadline rootwait
    EOF

    chroot "$BUILDROOT" adduser --disabled-password --gecos 'rpi,,,,' rpi
    echo 'rpi:rpi' | chroot "$BUILDROOT" chpasswd
    chroot "$BUILDROOT" adduser rpi sudo
    chroot "$BUILDROOT" adduser --disabled-login --shell /bin/false --gecos 'XBMC,,,' xbmc

    cat >> "$BUILDROOT/etc/network/interfaces" <<-EOF
    auto eth0
    iface eth0 inet dhcp
    EOF

    echo "xbmc" > "$BUILDROOT/etc/hostname"

    cat > "$BUILDROOT/etc/fstab" <<-EOF
    /dev/mmcblk0p1  /boot   vfat    defaults    0   0
    /dev/mmcblk0p2  /       ext4    errors=remount-ro,noatime,nodiratime    0   0
    EOF

    cat >> "$BUILDROOT/etc/modules" <<-EOF
    vchiq
    snd_bcm2835
    EOF
}

mkimage() {
    dd if=/dev/zero of="$IMAGE" bs=1MB count=0 seek="$IMAGE_SIZE"
    cat | sfdisk --quiet --unit S --force "$IMAGE" <<-EOF
    $ALIGN_SECTORS,$(($BOOT_SIZE*2048)),c,*
    $(($ALIGN_SECTORS+$BOOT_SIZE*2048)),,L

    EOF

    LOOP="$(basename $(losetup -f))"
    kpartx -a "$IMAGE"
    BOOT="/dev/mapper/${LOOP}p1"
    ROOT="/dev/mapper/${LOOP}p2"

    mkfs.vfat -F 32 -n boot "$BOOT"
    mkfs.ext4 -b 4096 -E stride=$ALIGN_FSBLOCKS,stripe-width=$ALIGN_FSBLOCKS -m 1 -L root "$ROOT"

    MNT="$(mktemp -d --tmpdir raspbian.XXXXXX)"
    mount "$ROOT" "$MNT"
    mkdir "$MNT/boot"
    mount "$BOOT" "$MNT/boot"

    rsync -rtvPHAX "$BUILDROOT" "$MNT"

    umount "$MNT/boot"
    umount "$MNT"

    kpartx -d "$IMAGE"
}

BUILDROOT="$(mktemp -d $PWD/raspbian.XXXXXX)/root/"
bootstrap
configure
mkimage

दिलचस्प। केवल एक चीज जो मैं सोच सकता हूं, वह यह है कि यह कर्नेल के समान वास्तुकला के लिए संकलित नहीं किया गया था।
Jivings

1
@ शिवलिंग मेरे रास 1 हैश ऑफ /sbin/initद फाइल को आधिकारिक रास्पियन छवि में फ़ाइल करता है ...
mgorven

यह सब साबित करता है कि आपका init अधिकारी के समान है। मैंने ऐसा नहीं कहा था। कर्नेल को अलग-अलग झंडों के साथ संकलित किया गया होगा
Jivings

@ जीव ओह, सही है। जहां तक ​​मैं समझता हूं कि Qemu का उपयोग करते समय कर्नेल बाहरी है, इसलिए यह वही है और आधिकारिक छवि काम करती है।
मॉर्गन

cmdline.txtफाउंडेशन से आपकी तुलना कैसे होती है ?
एलेक्स चेम्बरलेन

जवाबों:


5

समस्या यह थी कि निर्माण निर्देशिका से छवि में rsync डिवाइस और विशेष फ़ाइलों की प्रतिलिपि नहीं बना रहा था, और पर्याप्त फ़ाइल विशेषताओं को संरक्षित नहीं कर रहा था। विशेष रूप से, मैं जोड़ने के लिए की जरूरत है --archive, --devicesऔर --specialsविकल्प है, तो आदेश अब इस तरह दिखना:

rsync --archive --devices --specials --hard-links --acls --xattrs --sparse --verbose

यह अब Qemu के तहत ठीक है।


क्या आप इसे लिखने जा रहे हैं? यह स्व-उत्तर वाले प्रश्न के रूप में बहुत अच्छा होगा; मैं एक कस्टम रास्पियन छवि कैसे बनाऊं?
एलेक्स चेम्बरलेन

क्या यह बेहतर नहीं होगा कि एक ब्लॉग को एक उत्तर में करने के बजाय एक कस्टम छवि कैसे बनाई जाए। मुझे यकीन है कि इसके कोड की कुछ पंक्तियाँ नहीं होंगी।
पियोट्र कुला

@AlexChamberlain मैं कोशिश करूँगा कि ऐसा करने का समय मिले।
मॉर्गन

मैंने अपने ब्लॉग पर वर्किंग स्क्रिप्ट पोस्ट की है ।
मॉर्गन

0

यह त्रुटि संदेश आपके रूट फ़ाइल सिस्टम को माउंट करने के लिए एक initramfs के लिए पूछ रहा है। मुझे लगता है कि आपने एक गलत ड्राइवर या सुविधा को जोड़ा या हटा दिया है और कर्नेल ठीक से बूट करने में असमर्थ है। यह भी बताता है कि एक आधिकारिक छवि सामान्य रूप से क्यों बूट हो रही है।

यदि यह वास्तव में समस्या है, तो आपके पास दो विकल्प हैं:

  1. पता करें कि कौन सा ड्राइवर या फ़ीचर हटा दिया गया था और इसे वापस रख दिया गया। यह भी सुनिश्चित करें कि एक मॉड्यूल के रूप में नकाब न करें, लेकिन मुख्य कर्नेल छवि का निर्माण करें। मैं यह सलाह देता हूं।
  2. एक initramfs बनाएँ। बहुत अधिक परेशानी, ऐसा मत करो।
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.