u-boot移植(十三)---代码修改---裁剪及环境变量 二

一、错误处理

  上一节遇到一个错误:

  u-boot移植(十三)---代码修改---裁剪及环境变量 二

  print一下:

  u-boot移植(十三)---代码修改---裁剪及环境变量 二

  发现我们在jz2440.h中静态写的网络参数都没有写进去。

  dm9000 address not set。 dm9000的地址未设置。

  u-boot移植(十三)---代码修改---裁剪及环境变量 二

  这里对应两个函数:

  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。在文件中查找一下,这个宏定义的是什么:

  u-boot移植(十三)---代码修改---裁剪及环境变量 二

  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命令:

  u-boot移植(十三)---代码修改---裁剪及环境变量 二

  u-boot移植(十三)---代码修改---裁剪及环境变量 二

  jz2440.h中定义宏:

  定义宏 CONFIG_CMD_MTDPARTS 打开 mtdparts命令

  修改run_main_loop函数:

  u-boot移植(十三)---代码修改---裁剪及环境变量 二

  mtdparts_init() 函数的作用就是构造分区,这些分区都是用数组表示的。

  查看其他地方的设置分区,仿照写入,如下:

  u-boot移植(十三)---代码修改---裁剪及环境变量 二

  编译运行,结果如下:

  u-boot移植(十三)---代码修改---裁剪及环境变量 二

  这里有个提醒:mtdparts variable not set, see 'help mtdparts'         no partitions defined

  这是因为没有带参数,下面已经打印出分区了。

  执行两条命令建立分区,如下:

  u-boot移植(十三)---代码修改---裁剪及环境变量 二

  擦除分区:

  u-boot移植(十三)---代码修改---裁剪及环境变量 二

  加入代码,自动执行分区的两条命令:

 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启动命令行

  就两条命令:

  u-boot移植(十三)---代码修改---裁剪及环境变量 二

  执行bootm就可以启动内核了

  

上一篇:(转)SVN服务器搭建和使用(一)


下一篇:SVN在eclipse的整合应用