作为一个新人,怎样学习嵌入式 Linux?

 作为一个新人,怎样学习嵌入式 Linux? ? 

作为一个新人,怎样学习嵌入式 Linux?被问过太多次,特写这篇文章来回答一下。

 肯定要有 C 语言基础。 汇编基础有没有无所谓(就那么几条汇编指 在学习嵌入式 Linux 之前, 令,用到了一看就会)。 C 语言要学到什么程度呢?越熟当然越好,不熟的话也要具备基本技能。比如写一个数组排 序、输入数字求和什么的。 学 C 语言唯一的方法是多写程序多练习,编译出错没关系,自己去解决;执行出错没关系, 自己去分析。以前我是用 VC 来练习 C 语言的,经常去尝试着写一些 C 语言竞赛的题目。它 们是纯 C、纯数学、纯逻辑的题目,不涉及界面这些东西,很适合煅炼你的编程能力。 

回到主题,首先我们要明白你的目的是什么,大概来说所谓嵌入式 Linux 可以分为两部分: 底层系统、应用开发。 如果你是想做应用开发,那么你去把 C 语言、数据结构、JAVA 什么的学好吧。嵌入式应用 开发和 PC 上的应用开发并没有什么特别要注意的。 也许你说在嵌入式上要做些优化, 是的, 要优化, 但是未经优化的程序和 PC 上的程序开发没什么差别。 另外, 当你有能力去优化时, 你已经不用来问这个问题了。具体到某个例子,比如说开发界面,在 PC 上我们用 VC;在嵌 入式 Linux 里也许我们用 QT 也许用 Android,这个时候你应该去学学 QT、Android 的编程。 但是基础还是 C 或 JAVA,在此基础上去熟悉它们的接口。你学过 VC 的话,也是要花时间去 了解那些类、控件的。 

如果你的目的是想学习底层系统,这我的专长,倒是可以说一点。 在回答这个问题之前,我先回答:不少人问我,到底是学驱动还是学应用? 我只能说凭兴趣,并且驱动和应用并不是截然分开的

 1. 我们说的驱动,其实并不局限于硬件的操作,还有操作系统的原理、进程的休眠唤醒调 度等概念。 想写出一个好的应用,想比较好的解决应用碰到的问题,这些知识你应该懂

 2. 做应用门槛低,特别是现在的 ANDROID,纯 JAVA。做应用的发展路径个人认为就是业务 纯熟。 比如在通信行业、IPTV 行业、手机行业,你了解行业的需求。所以,当领导的人,多是做 应用的。 

3. 做驱动,其实我不想称为“做驱动”,而是想称为“做底层系统”,做好了这是通杀各行业。 我工作几年,做过手机、IPTV、会议电视,但是这些产品对我毫无差别,因为我只做底层。 他们的业务跟我没关系。 当应用出现问题,他们解决不了时,我就会从内核角度给他们出主意,给他们提供工具。 做底层的发展方向,个人认为是技术专家。

 4. 其实,做底层还是做应用,之间并没有一个界线,有底层经验,再去做应用,你会感觉 很踏实。 有了业务经验,你再了解一下底层,很快就可以组成一个团队。 回到怎么学的问题上。

嵌入式 Linux 底层系统包含哪些东西?不要急,举一个例子你就知 道了。 

1. 电脑一开机,那些界面是谁显示的?是 BIOS,它做什么?一些自检,然后从硬盘上读入 windows,并启动它。 类似的,这个 BIOS 对应于嵌入式 Linux 里的 bootloader。这个 bootloader 要去 Flash 上读 入 Linux 内核,并启动它。

 2. 启动 windows 的目的是什么?当然是上网聊天什么的了。这些上网、聊天工具在哪? 在 C 盘、 盘上。 D 所以, windows 要先识别出 C 盘、 盘。 Linux 下我们称为根文件系统。 

 3. windows 能识别出 C 盘、D 盘,那么肯定能读写硬盘才行。这涉及的东西称为驱动程序。 当然不仅仅是硬盘,还有网卡、USB 等等。 嵌入式 Linux 能从 Flash 上读出并执行应用程序,肯定也得有 Flash 的驱动程序啊,当然也 不仅仅是 Flash。

 先说到这里吧,嵌入式LINUX 里含有 bootloader, 内核, 驱动程序、 根文件系统这 4 大块

 一、bootloader: 它就是一个稍微复杂的裸板程序。但是要把这裸板程序看懂写好一点都不容易。Windows 下好用的工具弱化了我们的编程能力。 很多人一玩嵌入式就用 ADS、KEIL。你能回答这几个问题吗?

 1. 一上电,CPU 从哪里取指令执行? 

答:一般从 Flash 上指令。

 2. 但是 Flash 一般是只能读不能直接写的,如果我用到全局变量,这些全局变量在哪里? 

答:全局变量应该在内存里

 3. 那么谁把全局变量放到内存里去? 

答:长期用 ADS、KEIL 的朋友,你能回答吗?这需要"重定位"。在 ADS 或 KEIL 里,重定位 的代码是制作这些工具的公司帮你写好了。你可曾去阅读过? 

4. 内存那么大,我怎么知道把"原来存在 Flash 上的内容"读到内存的"哪个地址去"? 

答:这个地址用"链接脚本"决定,在 ADS 里有 scatter 文件,KEIL 里也有类似的文件。但 是,你去研究过吗?

 5. 你说重定位是把程序从 Flash 复制到内存,那么这个程序可以读 Flash 啊? 

答:是的,要能操作 Flash。当然不仅仅是这些,还有设置时钟让系统运行得更快等等。 


先自问自答到这里吧,bootloader 这一个裸板程序,其实有两部分要点: 

1. 对硬件的操作 2. 对 ARM 体系处理器的了解3. 程序的基本概念:重定位、栈、代码段数据段 BSS 段什么的。 

对硬件的操作,需要看原理图、芯片手册。这需要一定的硬件知识,不求你能设计硬件, 但是至少能看懂; 不求能看懂模拟电路,但是要能看懂数字电路。这方面的能力我是在学校 里学到的,微机原理、数字电路这 2 本书(书名忘了)就足够了。但是我怀疑你有无耐心把这 2 本书看完。我不知道现在有没有更快捷的书。想速成的话,就先放掉这块吧,不懂就问 GOOGLE、发贴。 

另外,芯片手册是肯定要读的,别去找中文的,就看英文的。开始是非常痛苦,以后就会发 现那些语法、词汇一旦熟悉后, 读任何芯片手册都很容易。

  对 ARM 体系处理器的了解, 看杜春蕾的<ARM 体系架构与编程>吧,里面讲有汇编指令,有 异常模式、MMU 等。也就这 3 块内容需要你了解。

 程序的基本概念,王道当然是去看编译原理了。可惜,这类书绝对是天书级别的。劝你若非 超级天才还是别去看了。就看我写的<嵌入式 Linux 应用开发完全手册>和第 1 期视频吧,别 担心,不用花钱。照着视频把硬件相关的实验做了,这些概念就清楚了。我还没有发现第 2 套讲这些概念的书或视频,允许我盲目吹嘘一回。 

对于 bootloader, 我学习时是先看了<ARM 体系架构与编程>, 然后自己写程序把各个硬件的 实验都做了一遍,比如 GPIO、时钟、 SDRAM、UART、NAND。把它们都弄清楚了,组台在一起就很容易看懂 u-boot 了 总结一下,看懂硬件原理图、看芯片手册,这需要你自己去找资料。剩下的,就按<嵌入式 Linux 应用开发完全手册>和第 1 期视频的章节目录去学习吧。


 二、内核: 想速成的人,先跨过内核的学习,直接学习怎么写驱动。 想成为高手,内核必须深刻了解。注意,我说的是了解,我没奢望去写出一个内核。 要对里面的调度机制、内存管理机制、文件管理机制等等有所了解。

 推荐两本书: 1. 通读<linux 内核完全注释>,请看薄的那本(浮燥的社会讲求速度, 呵), 2. 选读<Linux 内核情景分析>, 相了解哪一块就读哪一节 


三、驱动: 驱动包含两部分:硬件本身的操作、驱动程序的框架。 又是硬件,还是要看得懂原理图、读得懂芯片手册,多练吧。

 说到驱动框架,有一些书介绍一下。LDD3,即<Linux 设备驱动>,老外写的那本,里面介绍了 不少概念,值得一读。但是,它的作用也就限于介绍概念了。我基本上是入门之前用它来熟 悉一下概念,入门后就扔掉了。 驱动方面比较全的介绍,应该是宋宝华的<linux 设备驱动开发详解>了,老实说我只看过目 录,有不少人说好,这里推荐一下。 要想深入了解某一块, <Linux 内核情景分析>绝对是超 5 星级推荐。 你别指望把它读完, 1800 多页,上下两册呢。我是某一块不清楚 时,就去翻一下它。任何一部分,这书都可以讲上 2、3百页,非常详细。并且是以某个目 标来带你分析内核源码。它以 linux 2.4 为例, 但是原理相通,同样适用于其它版本的 linux。 还有没有其他介绍?

呵呵,当然有了,韦东山 Linux 视频第 2 期。<嵌入式 Linux 应用开发完 全手册>里对驱动讲得不多,不够深入。 于是我录制了这期视频。不仅仅教你怎么写怎么改驱动,还教你为什么这样写这样改驱动。 每一个驱动都是现场编写: 

1.用绘图板画图讲解——相当于学校里老师在黑板上画图讲解,很直观 绝对不是对着 PPT 念。

 2. 用 source insight 当然写程序,从第 1 行开始写,每一课都是这样。我讲了 20 多个驱动, 就写了 20 多个程序。

 3. 写完就编译、测试。

 4. 很全面,字符设备驱动、块设备、网卡驱动 3 大类齐全,硬件介绍、驱动框架分析、测 试 3 大类齐全。 

培训机构里教的内容,远不及这期视频丰富。我在多个培训机构讲过课,从没看到哪个老 师敢每一课都当场讲解当场编写代码 当场测试,除我之外!也没看到哪个培训机构讲完这些内容——因为时间不够,讲完起码要 一个月,但是这部分基本只有 2 周授课时间。 把你手上的开发板所涉及的硬件,都去尝试写一个驱动吧。有问题就先"痛苦地思考",思考 的过程中你会把很多不相关的知识 串联起来,最终贯通。


 四、根文件系统:大家有没有想过这 2 个问题: 

1. 对于 Linux 做出来的产品,有些用作监控、有些做手机、有些做平板。那么内核启动后, 挂载根文件系统后,应该启动哪一个应用程序呢? 

答:内核不知道也不管应该启动哪一个用户程序。它只启动 init 这一个应用程序,它对应 /sbin/init。 显示,这个应用程序就要读取配置文件,根据配置文件去启动用户程序(监控、手册界 面、平板界面等等) 这个问题提示我们,文件系统的内容是有一些约定的,比如要有/sbin/init,要有配置文 件 

2. 你写的 hello,world 程序,有没有想过里面用到的 printf 是谁实现的? 

答:这个函数不是你实现的,是库函数实现的。它运行时,得找到库。 这个问题提示我们,文件系统里还要有库。


 简单的自问自答到这里,要想深入了解,可以看一下 busybox 的 init.c,就可以知道 init 进程做的事情了。 当然,也可以看<嵌入式 Linux 应用开发完全手册>里构建根文件系统那章。 

说一下我的学习经历吧。 

1. 我在学校时读的是物理电子专业,其实课程里没有教怎么设计电路,只是教了些电子电 路方面的知识。PCB 的设计 是在实验室里自学的,只设置过 2 层板,现在忘记得差不多了。但是保留了看原理图、看 芯片手册的能力。

 2. 选修了软件学位,对软件设计挺感兴趣,但是也只是学了 C 语言、数据库而已。凭着兴 趣做了不少竞赛题。没能力去 参加竞赛,但是把 C 语言练得很扎实。 

3.在实验室、在第 1 家公司,就是设计些简单的 PCI 卡,写一下 windows 的驱动程序

 4. 在第 2 家公司,用 51 单片机做车载电话,开始走上纯软件的道路。

 5. 开始感到单片机的不足,辞职半年闭门学 Linux,从 red hat 怎么操作开始。步骤就是先 看<ARM 体系架构与编程>, 再自己写裸板程序操作硬件, 接着到分析 u-boot。 同时看<linux 内核完全注释>,对 LINUX 框架有所了解。 在写裸板时,建议各位加强对中断的理解,内核就是用中断来完成各种功能的。 

6. 分析完 u-boot,就开始进行简单的驱动编程了,这时候,能力还很弱。

 7. 开始去中兴上班,工作 2 年,编写各类驱动、解决各类问题(驱动问题、帮助定位应用问 题),能力得到煅炼。


  总结一下:1. 硬件方面的书: 微机原理、数字电路,高校里的教材。毕业多年,忘名了。 2. Linux 方面的书: <ARM 体系架构与编程> <嵌入式 Linux 应用开发完全手册> <Linux 设备驱动>,老外写的那本 <linux 设备驱动开发详解> <linux 内核完全注释> <Linux 内核情景分析>

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值