u-boot移植(六)---代码修改---串口

一、代码流程

1.1 串口代码

  程序流程图如下;

  

  default_serial_console 执行的代码如下:

  

  

  在JZ2440.H中有如下定义:

  

   则执行结构体s3c24xx_serial0_device,从而执行INIT_S3C_SERIAL_STRUCTURE(0, "s3ser0"):

  

  _serial_setbrg 为串口时钟设置函数:

  

  其中,调用get_PCLK()进行串口时钟的设置:

  

  PCLK的计算涉及到 HCLK,在函数中调用了get_HCLK() 来获取HCLK的值。

  

  get HCLK的代码就HCLK的计算,这里对应着寄存器CLKDIVN:

  

  此时我们已经不需要在往下分析了。从我们的代码上看,设置与配置都没有问题,宏的定义已经存在了。也不需要配置了,但是u-boot启动后却无法打印CPU信息。

  那么就只能看看u-boot.dis文件了,看我们的代码流程执行的是否与我们所想的代码流程一样。

二、串口打印

  首先我们定位到串口的初始化:

  

  在38a8这个地址执行了跳转,跳转到了 2e43c  serial_initalize 串口初始化函数,查找2e43c 进入串口初始化:

  

  这里再执行了跳转,跳转到了 serial_fin_console_or_panic 这个函数,这里就感觉优点不对了,我们分析的串口初始化的跳转应该是跳转到s3c24xx_serial_initialize() 这个函数中,去执行。Serial.c (drivers\serial) 

  这里跳转是跳转到serial_initialize()中,然手再跳转到serial_find_console_or_panic 去执行。这两个函数都在Serial-uclass.c (drivers\serial)中。

  代码执行的流程不对了,就要看看makefile中的配置是否正确了。

  在 drivers/serial/Makefile 中有如下定义:

  

  查一看 CONFIG_DM_SERIAL 在哪里有定义:

  

  

  在 include/configs/jz2440.h 的文件中,是没有定义CONFIG_DM_SERIAL 的,但是我们看到在 include/generated/autoconfig.h 中定义了CONFIG_DM_SERIAL 为1。

  同样 也看见生成的u-boot.cfg文件中,CONFIG_DM_SERIAL 有这一行。

  autoconfig.h文件是由.config文件自动生成的。因此我们可以直接修改我们的jz2440_defconfig文件来控制这个条件。但是不需要这么做,我们可以使用 make menuconfig 来控制:

  在u-boot 的根目录下执行命令: make menuconfig,然后按 “/” 搜索 CONFIG_DM_SERIAL 

  

  配置位置,看location 下面的,进入DEVICE Drivers->Serial drivers:

  

  这里默认配置了两项,上一张图的搜索中,Prompt 一栏说明了我们CONFIG_DM_SERIAL对应的是 Enable Driver Model for serial drivers,选择它,然后选择help 查看信息:

  

  意思是:使能串口驱动模型。这个模型是用串口 uclass 来替代 drivers/serial/serial.c ,uclass 实现 serial_putc() 等。uclass 接口被定义在 include/serial.h 中。

  我们不需要此配置,所以取消选中,保存退出。

  重新编译u-boot,然后生成dis文件。

  再看下串口初始化的位置:

  

  接着跳转到我们需要的文件中去了:

  

  执行烧写,查看结果,由于本人的是WIN10系统,运行DNW造成[ERROR:Can't create dnw.ini],因此直接用JTAG进行烧写,烧写完成后,显示结果为:

   

  DNW兼容性不好,电脑好还是有JTAG直接进行烧写进 nor flash。用DNW发送文件后,烧写进nor flash虽然成功,但是报错[ERROR:Can't create dnw.ini]造成uart无法显示结果。

posted @ 2017-06-08 03:20  游戏进行中  阅读(3421)  评论(0编辑  收藏  举报