uboot- MMC sem cartão SD
-
13-12-2019 - |
Pergunta
Estou tentando obter um kernel Linux com um rootfs Linux rodando em uma placa Freescale imx51.
Compilei o kernel do Linux, o sistema de arquivos raiz e o u-boot e copiei a imagem para o cartão SD:partição 0:partição de inicialização 1:rootfs e kernel do linux
Porém estou com o seguinte erro:
U-Boot 2011.12 (Mar 13 2012 - 14:15:41)
CPU: Freescale i.MX51 family rev3.0 at 800 MHz
Reset cause: POR
Board: MX51EVK
DRAM: 512 MiB
WARNING: Caches not enabled
MMC: FSL_SDHC: 0, FSL_SDHC: 1
MMC: no card present
MMC init failed
Using default environment
In: serial
Out: serial
Err: serial
Net: FEC
Warning: failed to set MAC address
Hit any key to stop autoboot: 0
MX51EVK U-Boot > mmcinfo
MMC: no card present
Device: FSL_SDHC
Manufacturer ID: 0
OEM: 0
Name: Tran Speed: 0
Rd Block Len: 0
MMC version 0.0
High Capacity: No
Capacity: 0 Bytes
Bus Width: 0-bit
MX51EVK U-Boot > mmc init
mmc - MMC sub system
Usage:
mmc read addr blk# cnt
mmc write addr blk# cnt
mmc erase blk# cnt
mmc rescan
mmc part - lists available partition on current mmc device
mmc dev [dev] [part] - show or set current mmc device [partition]
mmc list - lists available devices
MX51EVK U-Boot > mmc list
FSL_SDHC: 0
FSL_SDHC: 1
MX51EVK U-Boot > mmc dev
MMC: no card present
mmc0(part 0) is current device
MX51EVK U-Boot >
O que pode estar errado?
Solução
Verificando os interruptores DIP, percebi que o interruptor estava configurado para inicializar o cartão SD no slot inferior enquanto eu inicializava no slot superior.Assim resolveu meu problema
Outras dicas
no arquivo ./board/freescale/mx51evk/mx51evk.c
int board_mmc_init(bd_t *bis)
{
u32 index;
s32 status = 0;
esdhc_cfg[0].sdhc_clk = mxc_get_clock(MXC_ESDHC_CLK);
esdhc_cfg[1].sdhc_clk = mxc_get_clock(MXC_ESDHC2_CLK);
}
De acordo com os trechos de código acima, sugiro verificar a fonte do relógio.Tente testar o relógio na fonte MMC0.Pode haver problema na fonte do relógio.