一、错误处理
上一节遇到一个错误:
print一下:
发现我们在jz2440.h中静态写的网络参数都没有写进去。
dm9000 address not set。 dm9000的地址未设置。
这里对应两个函数:
static int eth_pre_unbind(struct udevice *dev) 和 int eth_write_hwaddr(struct eth_device *dev, const char *base_name, int eth_number)
这里两个函数对应着宏 CONFIG_DM_ETH。在文件中查找一下,这个宏定义的是什么:
config中没有设置,则运行的应该是后面一个函数。后面一个函数是设置硬件地址。
打印地址处的代码如下:
#ifdef CONFIG_NET_RANDOM_ETHADDR
net_random_ethaddr(dev->enetaddr);
printf("\nWarning: %s (eth%d) using random MAC address - %pM\n",
dev->name, eth_number, dev->enetaddr);
#else
printf("\nError: %s address not set1.\n",
dev->name);
return -EINVAL;
#endif
env_enetaddr 是从eth_getenv_enetaddr_by_index此函数中获取到的。
eth_getenv_enetaddr_by_index(base_name, eth_number, env_enetaddr); int eth_getenv_enetaddr_by_index(const char *base_name, int index,
uchar *enetaddr)
{
char enetvar[];
sprintf(enetvar, index ? "%s%daddr" : "%saddr", base_name, index);
return eth_getenv_enetaddr(enetvar, enetaddr);
}
从几个函数中我们可以知道,如果我们的dev->enetaddr是0,则就会打印那条错误信息。
试了好几个方法,都未成功设置,先放置在这里,进行其他的工作。
二、nand分
u-boot中输入mtdparts命令:
jz2440.h中定义宏:
定义宏 CONFIG_CMD_MTDPARTS 打开 mtdparts命令
修改run_main_loop函数:
mtdparts_init() 函数的作用就是构造分区,这些分区都是用数组表示的。
查看其他地方的设置分区,仿照写入,如下:
编译运行,结果如下:
这里有个提醒:mtdparts variable not set, see 'help mtdparts' no partitions defined
这是因为没有带参数,下面已经打印出分区了。
执行两条命令建立分区,如下:
擦除分区:
加入代码,自动执行分区的两条命令:
static int run_main_loop(void)
{
#ifdef CONFIG_SANDBOX
sandbox_main_loop_init();
#endif
// mtdparts_init(); /* 分区命令初始化 */
run_command("mtdparts default",); /* 自动执行分区命令 */
/* main_loop() can return to retry autoboot, if so just run it again */
for (;;)
main_loop();
return ;
}
编译运行就可以看到效果了。
三、加入kernel启动命令行
就两条命令:
执行bootm就可以启动内核了