0

wiki-xilinx-linuxの手順に従って、ザイリンクス システムで Linux を起動しようとしています。多くの異なるテストを行った後、(とりわけ)ここを調べた後、オプション "LOW LEVEL KERNEL DEBUGGING AND EARLYPRINTKs" を有効にしました。このおかげで、次のことがわかりました。

U-Boot 2016.07-03720-g95e11f6 (Oct 13 2016 - 03:48:21 -0700)

Model: Zynq MMC:   sdhci@e0100000: 0
SF: Detected S25FL256S_64K with page size 256 Bytes, eIn:    serial@e0001000
Out:   serial@e0001000
Err:   serial@e0001000
Model: Z00b000
Hit any key to stop autoboot:  0 
Copying Linux from SD to RAM...
Device: sdhci@e0100000
Manufacturer ID: 2
OEM: 544d
Name: SA04G 
Tran Speed:reading uImage
3842280 bytes read in 342 ms (10.7 MiB/s)
reading devicetree.dtb
8955 bytes read in 20 ms (436.5 KiB/s)
## Booting kernel from Legacy Image at 0008000
   Entry Point:  00008000
   Verifying Checksum ... OK
## Flattened Device Tree blob at 02a00000
   Booting using the fdt blob at OK
   Loading Device Tree to 1eb0e000, end 1eb132fa ... OK

Starting kernel .... done, booting the kernel.
Booting Linux on physical CPU 0x0
Linux version 4.6.0-xilinx-22282-g7d819bd (leProcessor [413fc090] revision 0 (ARMv7), cr=18c5387d
CPU: PIPT / VIPT nonaliasiMemory policy: Data cache writealloc
percpu: Embedded 12 pages/cpu @debcd000 s1115200 root=/dev/mmcblk0p2 rw rootwait
PID hash table entries: 2048 (order: 1, (order: 5, 131072 bytes)
Memory: 494528K/524288K available (5304K kernel code, or  : 0xffff0000 - 0xffff1000   (   4 kB)
    fixmap  : 0xffc00000 - 0xfff00000( 512 MB)
    pkmap   : 0xbfe00000 - 0xc0000000   (   2 MB)
    modules : 0xbf   .data : 0xc0900000 - 0xc0939b60   ( 231 kB)
       .bss : 0xc0939b60 - 0xc09R_CPUS=4 to nr_cpu_ids=2.
RCU: Adjusting geometry for rcu_fanout_leaf=32, nr_cp00 -> 0x72760000
L2C: DT/platform modifies aux control register: 0x72360000 -> ortex-A9
L2C-310 ID prefetch enabled, offset 1 lines
L2C-310 dynamic clock gatnq_clock_init: clkc starts at e0802100
Zynq clock init
sched_clock: 64 bits at_idle_ns: 440795209040 ns
Switching to timer-based delay loop, resolution 3ns
my device 80x30
Calibrating delay loop (skipped), value calculated using timer )
Mountpoint-cache hash table entries: 1024 (order: 0, 4096 bytes)
CPU: Testinx100058
CPU1: thread -1, cpu 1, socket 0, mpidr 80000001
Brought up 2 CPUs
SMP
   VFP support v0.3: implementor 41 architecture 3 part 30 variant 9 rev 4
clocksT: Registered protocol family 16
DMA: preallocated 256 KiB pool for atomic cohe maximum watchpoint size is 4 bytes.
zynq-ocm f800c000.ocmc: ZYNQ OCM pool: 256interface driver usbfs
usbcore: registered new interface driver hub
usbcore: r00
pps_core: LinuxPPS API ver. 1 registered
pps_core: Software ver. 5.3.6 - CoLinux Sound Architecture Driver Initialized.
clocksource: Switched to clocksourle entries: 4096 (order: 3, 32768 bytes)
TCP: Hash tables configured (establish (order: 1, 8192 bytes)
NET: Registered protocol family 1
RPC: Registered nameRegistered tcp NFSv4.1 backchannel transport module.
hw perfevents: enabled witx_order=17 bucket_order=0
jffs2: version 2.2. (NAND) (SUMMARY)  © 2001-2006 Rever for PL330 DMAC-241330
dma-pl330 f8003000.dmac:    DBUFF-128x8bytes Num_Chans-led
xdevcfg f8007000.devcfg: ioremap 0xf8007000 to e086c000
[drm] Initialized brd: module loaded
loop: module loaded
CAN device driver interface
libphy: MACB_mii_bus: probed
macb e000b000.ethernet eth0: Cadence GEM rev 0x00020118 at 0xe000b000 irq 145 (0rne:00, irq=-1)
e1000e: Intel(R) PRO/1000 Network Driver - 3.2.6-k
e1000e: Copci-pci: EHCI PCI platform driver
usbcore: registered new interface driver usb-si2c /dev entries driver
EDAC MC: ECC not enabled
Xilinx Zynq CpuIdle Driver ste Ossman
sdhci-pltfm: SDHCI platform and OF driver helper
mmc0: Invalid maximummc0: SDHCI controller on e0100000.sdhci [e0100000.sdhci] using ADMA
ledtrig-cphid: USB HID core driver
NET: Registered protocol family 10
sit: IPv6 over IPv4 tunneling driver
NET: Registered protocol family 17
can: controller ar protocol (rev 20120528 t)
can: netlink gateway (rev 20130117) max_hops=1
Regards found.
Waiting for root device /dev/mmcblk0p2...
mmc0: new high speed SDHCmmcblk0: p1 p2
VFS: Cannot open root device "mmcblk0p2" or unknown-block(179,2): error -30
Ple4 ram1  (driver?)
0102           16384 ram2  (driver?)
0103           16384 ra     16384 ram7  (driver?)
0108           16384 ram8  (driver?)
0109          0c           16384 ram12  (driver?)
010d           16384 ram13  (driver?)
010e ?)
b300         3813376 mmcblk0  driver: mmcblk
  b301         1048576 mmcblk0: Unable to mount root fs on unknown-block(179,2)
CPU1: stopping
CPU: 1 PID: 0nd_backtrace) from [<c010a608>] (show_stack+0x10/0x14)
[<c010a608>] (show_stackb24>] (ipi_cpu_stop+0x3c/0x70)
[<c010cb24>] (ipi_cpu_stop) from [<c010d394>] (h4>] (__irq_svc+0x54/0x90)
Exception stack(0xde46ff70 to 0xde46ffb8)
ff60:     01 debdc5c0 474d4ec6 00000000 45283f08 00000000 00000000 00000000
ffa0: 0000000/0x1c0)
[<c0492ccc>] (cpuidle_enter_state) from [<c014a72c>] (cpu_startup_entryFS: Unable to mount root fs on unknown-block(179,2)

仮想ファイル システムが不明なブロックから読み取ろうとしているようです。

VFS: Cannot open root device "mmcblk0p2" or unknown-block(179,2): error -30

グーグル、解決策は見つかりませんでした。これを解決する方法について誰か考えがありますか?どこで見ることができますか?どのパラメータで遊ぶ?

4

2 に答える 2

2

最後に、私が抱えていたすべての問題を解決しました (プログラマブル ロジックでカスタム ハードウェアを使用して Zybo で Linux を実行する)。はい、私は初心者なので、さまざまな問題が見つかりました。

1) 問題の 1 つは .dts にありました: の部分eFuseが完全に欠落していました。ザイリンクスは、問題を修正した別のバージョンの .dts をコミットしました。

2) もう 1 つの大きな問題は、ビットストリームにありました。最初は、実行中の Linux を使用して Zybo で PL をプログラムしたいと考えていましたcat bitstream.bit > /dev/xdevcfg。もちろん、[この wiki ページ][1] で説明されているように、これは完全に可能です (私はテストしました)。問題: FPGA にカスタム ハードウェアがある場合、デバイス ツリーにもその説明があります。カーネルは PS に接続されているすべてのペリフェリックを初期化しようとしますが、もちろん PL はまだ接続されていません!! 解決策は、正しい方法でboot.bifを生成するために、ビットストリームをダウンロードして に含めることです。boot.bin

    image : {
        [bootloader]fsbl.elf
        bitstream.bit
        u-boot.elf
        devicetree.dtb
        uramdisk.image.gz
        uImage.bin   // currently bootgen requires a file extension. this is just a renamed uImage
}

もちろん使用: bootgen -image boot.bif -o i boot.bin. 他にも小さな問題がありました。この回答の将来の編集 - 改訂でリストを追加しようとします。

アップデート:

質問で説明されている問題を解決するには、追加の問題/エラーがない場合bootargs、オプションを追加するだけで十分ですrootdelay=3( rootdelay— ルートファイルシステムをマウントする前に遅延する時間)。これは、u-boot が SD にアクセスしようとする速度が速すぎて、SD がまだ準備できていないために必要になる場合があります。

于 2016-11-02T15:29:06.963 に答える
1

SD カードの 2 番目のパーティションであるmmcblk0p2のルート ファイルシステムを使用するように設定しました。ファイルシステムが実際にそこに配置されている場合は、パーティションがフォーマットされたもの (ext3 など) をカーネルがサポートしていることを確認する必要があります。これはビルド済みのイメージですか、それとも自分で作成したイメージですか? ビルドする前にコマンドpetalinux-configを使用すると、ファイル システムを保存する場所の設定を変更できます。ところで、これは非常に一般的な問題であるため、Google で適切な用語を使用すれば、多くの情報が見つかるはずです。

于 2016-10-13T20:10:10.163 に答える