搜索
bottom↓
回复: 23

【图文】分享嵌入式学习方法--关于ARM+linux

[复制链接]

出0入0汤圆

发表于 2010-4-27 10:48:31 | 显示全部楼层 |阅读模式

(原文件名:嵌入式学习方法02.gif)

本文转引自      嵌入式学习网       http://www.witech.com.cn/

   谨将此文献给正在为自己的理想而不懈努力的朋友!

   由于很多人总问这个问题,所以这里做一个总结文档供大家参考。这里必须先说明,以下的步骤都是针对Linux系统的,并不面向WinCE。也许你会注意到,现在做嵌入式的人中,做linux研究的人远比做WinCE的人多,很多产家提供的资料也是以linux为主。我一直很难理解,其实WinCE的界面比linux的界面好看多了,使用起来也很方便,更为重要的是,WinCE的开发和Windows下的开发基本一样,学起来简单得多,但是学linux或者使用linux做嵌入式的人就是远比WinCE多。在和很多工作的人交流时我了解到,他们公司从没考虑使用WinCE,因为成本高,都是使用linux进行开发。我读研究生的的实验室中也没有使用WinCE的,大都研究linux,也有少部分项目使用vxwork,但是就没有听说过使用WinCE的,原因就是开源!当然现在WinCE6.0听说也开源,不过在成本和资源上linux已经有了无人能挡的优势。与此相对应的是,越来越多的电子厂商已经开始使用linux开发产品。举个例子,Google近期开发的智能手机操作系统Android其实就是使用linux-2.6.23内核进行改进得到的。

第一,学习基本的裸机编程。
  对于学硬件的人而言,必须先对硬件的基本使用方法有感性的认识,更必须深刻认识该硬件的控制方式,如果一开始就学linux系统、学移植那么只会马上就陷入一个很深的漩涡。我在刚刚开始学ARM的时候是选择ARM7(主意是当时ARM9还很贵),学ARM7的时候还是保持着学51单片机的思维,使用ADS去编程,第一个实验就是控制led。学过一段时间ARM的人都会笑这样很笨,实际上也不是,我倒是觉得有这个过程会好很多,因为无论做多复杂的系统最终都会落实到这些最底层的硬件控制,因此对这些硬件的控制有了感性的认识就好很多了
学习裸机的编程的同时要好好理解这个硬件的构架、控制原理,这些我称他为理解硬件。所谓的理解硬件就是说,理解这个硬件是怎么组织这么多资源的,这些资源又是怎么由cpu、由编程进行控制的。比如说,s3c2410中有AD转换器,有GPIO(通用IO口),还有nandflash控制器,这些东西都有一些寄存器来控制,这些寄存器都有一个地址,那么这些地址是什么意思?又怎么通过寄存器来控制这些外围设备的运转?还有,norflash内部的每一个单元在这个芯片的内存中都有一个相应的地址单元,那么这些地址与刚刚说的寄存器地址又有什么关系?他们是一样的吗?而与norflash相对应的nandflash内部的储存单元并不是线性排放的,那么s3c2410怎么将nandflash的地址映射在内存空间上进行使用?或者简单地说应该怎么用nandflash?再有,使用ADS进对ARM9行编程时都需要使用到一个初始化的汇编文件,这个文件究竟有什么用?他里面的代码是什么意思?不要这个可以吗?
诸如此类都是对硬件的理解,理解了这些东西就对硬件有很深的理解了,这对以后更深一步的学习将有很大的帮助,如果跳过这一步,我相信越往后学越会觉得迷茫,越觉得这写东西深不可测。因为,你的根基没打好。
不过先声明一下,本人并没有使用ADS对ARM9进行编程,我是学完ARM7后直接就使用ARM9学linux系统的,因此涉及使用ADS对ARM9进行编程的问题我很难回答^_^,自己去研究研究吧。
对于这部分不久将提供一份教程,这个教程中的例程并不是我为我们所代理的板子写的,是我在我们学院实验室拿的,英培特为他们自己的实验箱写的,不过很有借鉴意义,可以作为一份有价值的参考。

第二,使用linux系统进行一些基本的实验。
  在买一套板子的时候一般会提供一些linux的试验例程,好好做一段时间这个吧,这个过程也是很有意义的,也是为进一步的学习积累感性认识,你能想象一个从没有使用过linux系统的人能学好linux的编程吗?好好按照手册上的例程做一做里面的实验,虽然有点娃娃学走路,有点RZ,但是我想很多高手都会经历这个过程。
在这方面我们深蓝科技目前没有计划提供相应的例程,主要是开发板的提供商会提供很丰富的例程,我们不做重复工作,只提供他们没有的、最有价值的东西给大家。

第三,研究完整的linux系统的的运行过程。
  所谓完整的linux系统包括哪些部分呢?
  三部分:bootloader、linux kernel(linux内核)、rootfile(根文件系统)。
那么这3部分是怎么相互协作来构成这个系统的呢?各自有什么用呢?三者有什么联系?怎么联系?系统的执行流程又是怎么样的呢?搞清楚这个问题你对整个系统的运行就很清楚了,对于下一步制作这个linux系统就打下了另一个重要的根基。介绍这方面的资料网上可以挖掘到几吨,自己好好研究吧。

第四,开始做系统移植。
  上面说到完整的linux有3部分,而且你也知道了他们之间的关系和作用,那么现在你要做的便是自己动手学会制作这些东西。
当然我不可能叫你编写这些代码,这不实现。事实上这个3者都能在网下载到相应的源代码,但是这个源代码不可能下载编译后就能在你的系统上运行,需要很多的修改,直到他能运行在你的板子上,这个修改的过程就叫移植。在进行移植的过程中你要学的东西很多,要懂的相关知识也很多,等你完成了这个过程你会发现你已经算是一个初出茅庐的高手了。
在这个过程中如果你很有研究精神的话你必然会想到看源代码。很多书介绍你怎么阅读linux源代码,我不提倡无目的地去看linux源代码,用许三多的话说,这没有意义。等你在做移植的时候你觉得你必须去看源代码时再去找基本好书看看,这里我推荐一本好书倪继利的《linux内核的分析与编程》,这是一本针对linux-2.6.11内核的书,说得很深,建议先提高自己的C语言编程水平再去看。
  至于每个部分的移植网上也可以找到好多吨的资料,自己研究研究吧,不过要提醒的是,很多介绍自己经验的东西都或多或少有所保留,你按照他说的去做总有一些问题,但是他不会告诉你怎么解决,这时就要靠自己,如果自己都靠不住就找我一起研究研究吧,我也不能保证能解决你的问题,因为我未必遇到过你的问题,不过我相信能给你一点建议,也许有助你解决问题。
  这一步的最终目的是,从源代码的官方主页上(都是外国的,悲哀)下载标准的源代码包,然后进行修改,最终运行在板子上。
盗用阿基米德的一句话:“给我一根网线,我能将linux搞定”。

第五,研究linux驱动程序的编写。
  移植系统并不是最终的目的,最终的目的是开发产品,做项目,这些都要进行驱动程序的开发。
  Linux的驱动程序可以说是五花八门,linux2.4和linux2.6的编写有相当大的区别,就是同为linux2.6但是不同版本间的驱动程序也有区别,因此编写linux的驱动程序变都不是那么容易的事情,对于最新版本的驱动程序的编写甚至还没有足够的参考资料。那么我的建议就是使用、移植一个不算很新的版本内核,这样到时学驱动的编程就有足够的资料了。
这部分的推荐书籍可以参考另一篇文章《推荐几本学习嵌入式linux的书籍》。

第六,研究应用程序的编写。
  做作品做项目除了编写驱动程序,最后还要编写应用程序。现在的趋势是图形应用程序的开发,而图形应用程序中用得最多的还是qt/e函数库。我一直就使用这个函数库来开发自己的应用程序,不过我希望你能使用国产的MiniGUI函数库。盗用周杰伦的广告词就是“支持国产,支持MiniGUI”。MiniGUI的编程比较相似Windows下的VC编程,比较容易上手,效果应该说是相当不错的,我曾使用过来开发ARM7的程序。不过MiniGUI最大的不好就是没有像qtopia这样的图形操作平台,这大大限制了他的推广,我曾经幻想过与北京飞漫公司(就是MiniGUI的版权拥有者)合作使用MiniGUI函数库开发像qtopia这样的图形操作平台,不过由于水平有限这只能是幻想了,呵呵。
完成这一步你基本就学完了嵌入式linux的全部内容了。

  还有一个小小的经验想和大家分享。我在学习嵌入式linux的过程中很少问人,客观原因是身边的老师、同学师兄都没有这方面的高手,主观原因是我不喜欢问人,喜欢自己研究解决问题。这样做有个好处,就是可以提高自己解决问题的能力,因为做这些东西总有很多问题你难以理解,别人也没有这方面的经验,也不是所有问题都有人给你答案,这时必须要自己解决问题,这样,个人的解决问题能力就显得非常关键了。因此我的建议就是一般的问题到网上搜索一下,确实找不到答案了就问问高手,还是不行了就自己去研究,不要一味去等别人帮你解决问题。
  记住,问题是学习的最好机会。

阿莫论坛20周年了!感谢大家的支持与爱护!!

一只鸟敢站在脆弱的枝条上歇脚,它依仗的不是枝条不会断,而是自己有翅膀,会飞。

出0入0汤圆

发表于 2010-4-27 11:43:03 | 显示全部楼层
好文章,不过还没开始探索arm!

出0入0汤圆

发表于 2010-4-27 11:55:03 | 显示全部楼层
mark

出0入0汤圆

发表于 2010-4-27 11:55:27 | 显示全部楼层
呵呵,好熟悉的网址,当时学嵌入式的时候不少资料都是在这里找的。

出0入0汤圆

发表于 2010-4-27 12:12:40 | 显示全部楼层
按个爪印!

出0入0汤圆

发表于 2010-4-28 08:59:45 | 显示全部楼层

出0入0汤圆

发表于 2010-4-28 19:56:14 | 显示全部楼层
支持。

出0入0汤圆

发表于 2010-4-29 16:21:12 | 显示全部楼层
字符驱动编译错误(unrecognized option -march=i586)
2010-04-24 10:34
内容: make -C /lib/modules/2.6.31-20-generic/build SUBDIRS=/home/dengwei/ldd3_dw/arm_scull/scull_driver_test modules
make[1]: 正在进入目录 `/usr/src/linux-headers-2.6.31-20-generic'
  CC [M]  /home/dengwei/ldd3_dw/arm_scull/scull_driver_test/scull.o
Assembler messages:
Error: unknown architecture `i586'

Error: unrecognized option -march=i586
----------------------------------------------------------------------------------------------------------------------
在编译测试程序时,正确。
此测试程序,在pc机上测试成功。
-----------------------------------------------------------------------------------------------------------------
下面是字符驱动的Makefile,怀疑是它的问题。
CROSS_COMPILE =  /tq2440/cross/4.3.3/bin/arm-linux-
CC = $(CROSS_COMPILE)gcc
#CC = gcc

ifneq    ($(KERNELRELEASE),)
obj-m    :=scull.o

else
KDIR    :=/lib/modules/$(shell uname -r)/build
PWD    := $(shell pwd)

default:
    $(MAKE) -C $(KDIR) SUBDIRS=$(PWD) modules
clean:
    rm -r -f .tmp_versions *.mod.c .*.cmd *.o  Modules.symvers
endif
-----------------------------------------------------------------------------------------
还求大侠,指点迷津。
非常感谢。

出0入0汤圆

发表于 2010-5-5 22:06:56 | 显示全部楼层
路过,顺便学习

出0入0汤圆

发表于 2010-5-13 16:43:51 | 显示全部楼层
mark

出0入0汤圆

发表于 2010-5-16 20:38:45 | 显示全部楼层

出0入0汤圆

发表于 2011-3-20 11:16:23 | 显示全部楼层
mark

出0入0汤圆

发表于 2011-3-20 11:33:09 | 显示全部楼层
mark

出0入0汤圆

发表于 2011-3-22 18:36:38 | 显示全部楼层
学习

出0入0汤圆

发表于 2011-3-25 17:46:22 | 显示全部楼层
这正是我要的!!!

出0入0汤圆

发表于 2011-3-26 14:47:23 | 显示全部楼层
mark,顶。。。。。

出0入0汤圆

发表于 2011-3-26 15:20:29 | 显示全部楼层
mark

出0入0汤圆

发表于 2011-4-23 10:08:49 | 显示全部楼层
看来我走了条错误的路线!先把Linux系统研究了在来看ARM体系结构!结果搞的现在真的很痛苦!底层硬件的东西都不知道是怎么捏在一起的!

出0入0汤圆

发表于 2012-11-11 10:59:27 | 显示全部楼层
maked!!!!!

出0入0汤圆

发表于 2012-11-12 11:24:19 | 显示全部楼层
好些文章都看过,不过还是帮顶。

出0入0汤圆

发表于 2012-11-13 14:26:54 | 显示全部楼层
这篇文章,我印象中也看过~!
刚才有仔细读完了,受益匪浅~!
现在在学STM32,玩转后就开始进军嵌入式~!

出0入0汤圆

发表于 2012-11-15 00:39:26 | 显示全部楼层
学习了啊,谢谢

出0入0汤圆

发表于 2012-11-15 09:44:30 | 显示全部楼层
好文章,不过还没开始探索arm!

出0入0汤圆

发表于 2012-11-28 12:22:36 | 显示全部楼层
呵呵,我还是停留在裸机开发,找不着linux的门道啊
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-5-20 17:28

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表