修正Ok6410的U-Boot网络不可用

本文介绍了如何修改飞凌6410开发板的UBOOT源代码,将网络驱动从CS8900更改为DM9000,解决无法ping通和tftp不可用的问题。包括修改配置文件、读取MAC地址、修正MAR寄存器和复位操作等步骤。
 

通过使用uboot的网络功能可以更新ubook,烧写内核,文件系统,如果网络功能不可能,那还不如同变砖了一样.当然如果支持sd卡启动,可能通过sd卡完成这些功能,但是也太过麻烦了.飞凌的6410开发板提供的uboot的网络驱动是cs8900,但是实际上网卡是dm9000ae.

U-Boot源代码下载地址 http://www.linuxidc.com/Linux/2011-07/38897.htm
 

烧入后发无法ping通,tftp不可用,输出:

1.CS8900 Ethernet chip not found?! 
下面,提供简单的修改方法,把驱动改为dm9000,让网络功能用起来.

1.修改include/configs/smdk6410.h

1.#ifdef  CONFIG_DRIVER_SMC911X     
2.#undef  CONFIG_DRIVER_CS8900       3.#define CONFIG_DRIVER_SMC911X_BASE  0x18800300   4.#else   5.//注释掉下面3行   6.//#define CONFIG_DRIVER_CS8900  0   /* we have a CS8900 on-board */   7.//#define CS8900_BASE       0x18800300   8.//#define CS8900_BUS16      1   /* the Linux driver does accesses as shorts */   9.//增加下面4行   10.#define CONFIG_DRIVER_DM9000                1   11.#define CONFIG_DM9000_BASE          0x18000000   12.#define DM9000_IO                   CONFIG_DM9000_BASE   13.#define DM9000_DATA                 (CONFIG_DM9000_BASE+4)   14.#define CONFIG_DM9000_USE_16BIT   15.//#define CONFIG_DM9000_DEBUG   16.#endif  2.303行
从环境变量中读取MAC地址
把((u16 *) bd->bi_enetaddr)[i] = read_srom_word(i);替换为:
1.char *s, *e; 
2.s = getenv ("ethaddr");  3.for (i = 0; i < 6; ++i)   4.{ 
5.    bd->bi_enetaddr[i] = s ? simple_strtoul (s, &e, 16) : 0; 
6.    if (s)  7.        s = (*e) ? e + 1 : e; 
8.} 
3.修改318行,修改0x00为0xff
修改MAR寄存器(Multicast Address Register)的值,修正第一次收不到数据的错误
1.for (i = 0, oft = 0x16; i < 8; i++, oft++) 
2.    DM9000_iow(oft,0x00); 
3.    //DM9000_iow(oft, 0xff);  4.413行
注释掉下面2行
修正一直无法收到数据的错误,不要每次调用halt的时候都对PHY进行复位操作,否则会引起无法接受到数据的情况
1.void 
2.eth_halt(void)  3.{ 
4.    DM9000_DBG("eth_halt\n");  5. 
6. 
7.    /* RESET devie */  8.    //phy_write(0, 0x8000); /* PHY RESET */   9.    //DM9000_iow(DM9000_GPR, 0x01); /* Power-Down PHY */   10.    DM9000_iow(DM9000_IMR, 0x80);   /* Disable all interrupt */  11.    DM9000_iow(DM9000_RCR, 0x00);   /* Disable RX */  12.} 
这里只是根据别人的文章进行实现,的确可行,但是具体为什么这么做还有些问题需要自己去弄明白.


本篇文章来源于 Linux公社网站(www.linuxidc.com)  原文链接:http://www.linuxidc.com/Linux/2011-09/43804.htm

Safetycode start... Boot from NAND main area Boot from FMC0 Calculated hash:487488bf5e46500d6a5cb2594729cc9133e69b2ccee8fe506f84e0b333ac41a1 Expected hash :487488bf5e46500d6a5cb2594729cc9133e69b2ccee8fe506f84e0b333ac41a1 Startcode header hash verify successful Calculated hash:9c006751d21da10d4ca251c05bd6c44b95e3e5ff4d6c65d8a8ef30560c1b9e81 Expected hash :9c006751d21da10d4ca251c05bd6c44b95e3e5ff4d6c65d8a8ef30560c1b9e81 Startcode boot verify successful Status Information: 0x00000604 0x001cc7e9 0x000001c0 0xfffa0301 0x00000000 0x00000001 0x00000000 0x00000000 Jump to Startcode SPL: DDR_TYPE : 1GB SPL: BOOT_TYPE : 1 SPL: BOOT_MODE : BSBC SPL: CFG_VOLTAGE : 3.3V SPL: BOOT_CFG : 1 SPL: WATCHDOG_SEL: IN SPL: FLASH_TYPE : SFC0 use CS0 SPL: boot from FMC0 nand. 4M partition spl_early_init U-Boot SPL 2022.07-v1.26+-V1.26 (Sep 23 2025 - 05:44:41 +0000) cpu frequency is 600M SPL: bootsel0(0),bootsel2(1), bootsel3(1) SPL: boot from FMC0 nand, bootsel2(1) dram_init---- SPL: ddr init ok SPL: boot area main, mrureg7(0) >>SPL: board_init_r() spl_init SPL: bootsel0(0),bootsel2(1), bootsel3(1) SPL: boot from FMC0 nand, bootsel2(1) Trying to boot from NAND Fmc: if type mask = 0x3 Fmc: id[0] = 0xc8, id[1] = 0x95 Fmc: mf name GigaDevice, ids name GigaDevice Fmc: select read op, if type = 1 Fmc: select read op, opcode = 0x3b Fmc: select write op, if type = 0 Fmc: select write op, opcode = 0x2 Fmc: select update op, if type = 0 Fmc: select update op, opcode = 0x84 Fmc: select erase op, opcode = 0xd8 Fmc: spinand match manufacturer_id=0xc8 and dev_id=0x95 Fmc: ecc type = 16 Fmc: start init dev Fmc: disable ecc in spi nand cs0 Fmc: unlock spi nand block, cs(0) Fmc: start create chip ids Fmc: ids info: Fmc: name: GigaDevice: Fmc: mfr(0xc8) dev(0x95) Fmc: pagesize(0x800) Fmc: blocksize(0x20000) Fmc: oobsize(0x80) Fmc: chipsize(0x200) Fmc: options(0x10200) Fmc: ecc_strength(16) Fmc: ecc_step(1024) Fmc: GigaDevice SPI NAND was found. Fmc: 512 MiB, block size: 128 KiB, page size: 2048, OOB size: 128 Fmc: dma oob buffer ptr(0x8d0008d0) Fmc: real oob buffer ptr(0x8d0008d0) SPL: boot area main, mrureg7(0) mkimage signature not found - ih_magic = 0 Jumping to U-Boot SPL malloc() used 0x1d0 bytes (0 KB) loaded - jumping to U-Boot... !BOOT_LITEOS32 SPL: Next Image entry_point 0x80080000, load_addr 0x80080000 Jumping to U-Boot at address 0x80080000 SPL: bootsel0(0), bootsel1(1), bootsel2(1), bootsel3(1) SPL: boot from FMC0 nand, bootsel2(1) "Synchronous Abort" handler, esr 0x02000000 elr: 0000000080080000 lr : 00000000300a3d90 x0 : 0000000000000026 x1 : 0000000000000000 x2 : 000000000000001b x3 : 0000000000000020 x4 : 00000000fffffffc x5 : 0000000030081a28 x6 : 0000000000000031 x7 : 0000000030081d80 x8 : 0000000000000000 x9 : 00000000ffffffc8 x10: 00000000ffffffd8 x11: 000000000000000d x12: 0000000000000006 x13: 000000000001869f x14: 00000000300e0d90 x15: 0000000000000000 x16: 00000000300c49b8 x17: 000000003008a07c x18: 0000000030081e70 x19: 000000000000000e x20: 0000000000000001 x21: 0000000080080000 x22: 0000000030081e20 x23: 0000000000000004 x24: 0000000000000000 x25: 00000000deadbeef x26: 00000000300d2fe0 x27: 00000000300d2f00 x28: 0000000000000000 x29: 0000000030081d80 Code: 5d821535 89152b8f 5d89153f 39159b8f (00000000) Resetting CPU ...
09-24
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值