linux u-boot跟踪方法总结

拿到一块板子,其中很重要的一项就是看电路图还有Datasheet。

这个真的很重要,首先你要知道cpu的架构是什么,armv7?arvmv5?还是其他的,哪个公司的芯片?是freescale 还是TI还是MTK,还是samsung,Hisilicon还是一些其他的什么芯片,现在的CPU的数据手册都比较全,都很容易在官网找到相关的资料,但是还要在官网找到其他的一些有用的信息,比如说官方对于这个芯片有没有评估板,对于这块板子有哪些支持的系统,相关的工具,比如说烧写系统的工具,都是很有用的。

其实一款嵌入式产品,除了初期产品规划时候规划的功能以外,cpu已经给这款产品定了型。

今天就记录一下针对一款产品u-boot 的跟踪方法。

纯属个人土方法,不正确望指出。

1.如果拿到板子的时候已经给了一套系统给你,确定了正确的烧写方式,确定了正确的sysboot。那么就可以着手开始跟踪u-boot,在以前的随笔里有一些记录,但是也是不是很成熟很通俗易懂,今天讲一个比较俗的跟踪方法。

  首先,确定你的makefile 的正确配置,将这个u-boot配置一次,然后编译成功出来一次。

  就拿以前的tiny4412那块板子来说,u-boot的正确配置是 make tiny4412_config make -j8   编译成功后。

  他会生成几个重要的文件,u-boot.bin , u-boot.lds 第一个是编译完的二进制文件,第二个是编译链接脚本。

  我们开始的地点就是u-boot.lds.

  这里面会指定u-boot的开始位置,打个简单的比方,如果你的cpu是 armv7的架构,那个你的开始位置十有八九是arch/arm/cpu/armv7/start.S

  不要问我为什么,这是经验。但是上述情况也有特殊情况,具体要看u-boot.lds,如果实在不行就看这个这个文件下有没有start.o文件,有的话就是了。

  我的u-boot.lds是

1  .text :
2  {
3   arch/arm/cpu/armv7/start.o (.text)
4   board/samsung/tiny4412/libtiny4412.o (.text)
5   arch/arm/cpu/armv7/exynos/libexynos.o (.text)
6   *(.text)
7  }                                                                              

  这说明我的开始位置就是刚才那个,第二个文件就下下面那个。。。。

  那个文件还规定了入口是(_start)

  接下来就是  _start    reset   cpu_init_crit   board_init_f   relocate_code  board_init_r  main_loop   反正就是这个套路,顺着下去就是了,如果不确定这个文件是不是自己要进去的,那么就搜索一下这个文件的.o文件,如果有,一般来说就是,但是还要看include/configs/********.h  文件,这个文件我在前面也介绍了。

  如果你不知道u-boot的各个文件结构,看顶层文件的README应该有一些介绍。

  

时间: 2024-10-31 11:20:30

linux u-boot跟踪方法总结的相关文章

linux 安装VMware Tools 方法 (1)

虚拟机安装 VMware Tools for Linux 介绍: VMware Tools是VMware虚拟机中自带的一种增强工具,相当于VirtualBox中的增强功能(Sun VirtualBox Guest Additions),是VMware提供的增强虚拟显卡和硬盘性能.以及同步虚拟机与主机时钟的驱动程序. 只有在VMware虚拟机中安装好了VMware Tools,才能实现主机与虚拟机之间的文件共享,同时可支持自由拖拽的功能,鼠标也可在虚拟机与主机之前自由移动(不用再按ctrl+alt

Andoird Crash的跟踪方法,使用腾讯Bugly来捕捉一些疑难杂症,让我们APP稳定上线

Andoird Crash的跟踪方法,使用腾讯Bugly来捕捉一些疑难杂症,让我们APP稳定上线 我们在开发中常常会注意到一些Crash,这正是很头疼的,而且Crash会带来很多意想不到的状态,很恶心,所以今天,我们来着重研究一下Crash,同时,我们也将使用第三方SDK,也就是腾讯的Bugly来扑捉这些Crash,让他无所遁形. 一.糟糕的Android Crash 作为开发人员,很容易就能碰到Crash,但是作为用户,我相信也有很大部分人碰到过Crash,这些原因,也正是Android的平台

嵌入式linux应用程序调试方法

嵌入式linux应用程序调试方法 四 内存工具 17 4.1 MEMWATCH 17 4.2 YAMD 22 4.3 Electric Fence 24 五 C/C++代码覆盖.性能profiling工具 24 5.1 用gcov来测试代码覆盖率 25 5.2 使用gprof来优化你的C/C++程序 35 四 内存工具 您肯定不想陷入类似在几千次调用之后发生分配溢出这样的情形. 许多小组花了许许多多时间来跟踪稀奇古怪的内存错误问题.应用程序在有的开发工作站上能运行,但在新的产品工作站上,这个应用

P2V后LINUX系统开机处理方法

P2V后LINUX 处理 /boot/ sh-3.2# mkinitrd -v -f initrd-2.6.18-164.el5.img $(uname -r) 要打包的内核文件名     内核版本号 ##更新当前虚拟机的内核: #如果修复光盘与系统不一至的情况: $(uname -r)这里直接敲虚拟机的内核版本号: 问题集: 开机出现"Error loading operating system"的提示信息,只需要利用光盘进入恢复模式,修复一下grub就可以开机了,确保你的虚拟机硬盘

调试linux内核环境搭建方法(ddd+busybox+qemu+linux3.5.4内核)

环境搭建 1.1.准备工作 (1).qemu虚拟机 (2).busybox软件 (3).linux-3.5.4内核 (4).ddd 调试工具(终端中输入 sudo apt-get install ddd 安装) 1.2.编译内核 (1)建立工作目录:mkdir -p ~/work/qemu (2)切换到此目录:cd ~/work/qemu (3)下载 linux内 核 (4)解压内核:tar -jxvf linux-3.5.4.tar.bz2 (5)切换到linux-3.5.4目录: cd li

Linux UML 内核调试方法

Linux UML 内核调试方法小结 一 UML环境的搭建 1 下载內核 从官网www.kernel.org 选择版本 linux-3.10.57.tar.xz 解压到相应路径 ????/opt/um/linux-3.10.57 ? 2 基于 um的内核配置 #cd /opt/um/linux-3.10.57 #cp cd /boot/config-3.8.13.13-cdos .config # make olddefconfig ARCH=um ? 为方便进行调试,修改配置文件 #make

KCF目标跟踪方法分析与总结

KCF目标跟踪方法分析与总结 correlation filter Kernelized correlation filter tracking 读"J. F. Henriques, R. Caseiro, P. Martins, J. Batista, 'High-speed tracking with kernelized correlation filters'" 笔记 KCF是一种鉴别式追踪方法,这类方法一般都是在追踪过程中训练一个目标检测器,使用目标检测器去检测下一帧预测位置

linux获取随机数的方法集合

linux产生随机的方法 取8位数字的方法 [[email protected] scripts]# echo $RANDOM 12465 [[email protected] scripts]# echo $((RANDOM+10000000)) 10023190 [[email protected] scripts]# echo $RANDOM | md5sum | cut -c 1-8 ae74cedb [[email protected] scripts]# uuidgen| md5su

Linux网络性能优化方法简析

Linux网络性能优化方法简析 2010-12-20 10:56 赵军 IBMDW 字号:T | T 性能问题永远是永恒的主题之一,而Linux在网络性能方面的优势则显而易见,这篇文章是对于Linux内核中提升网络性能的一些优化方法的简析,以让我们去后台看看魔术师表演用的盒子,同时也看看内核极客们是怎样灵活的,渐进的去解决这些实际的问题. AD:2014WOT全球软件技术峰会北京站 课程视频发布 对于网络的行为,可以简单划分为 3 条路径:1) 发送路径,2) 转发路径,3) 接收路径,而网络性