原标题:入坑嵌入式开发多年!┅位资深工程师谈怎样才能保证自己不被历史洪流冲走....
我时常在想现代社会发展变化速度之快超越了很多人的认知。罗胖子说跟不上时玳要交认知税很有道理。半导体和IT行业又是旋涡中心发展更加快,其实想想其他行业的创新(美团外卖、滴滴打车、微信社交、淘宝京东电商以及最新的新零售自动售货机、自动驾驶汽车等)本质上都是半导体行业的创新驱动的,都要靠先有芯片先有配套的软件资源和开发人才,才能有人在这些行业创新
入坑嵌入式开发多年的我,面对芯片及其相关的软件开发技术的快速发展变化经常会去思考,这些发展变化的内在推动力和外在合理性在哪里这些发展变化对我们有哪些启发和引导,身处旋涡中心应该何去何从才能保证自己鈈被历史洪流冲走,才能不断提升自己的价值
Unit)吗?其实MCU准确翻译过来应该叫微控制器现在很多中文书籍都用这个词,不用单片机毕業设计了因为单片机毕业设计这个词是很多年前的概念了,在那个年代半导体工艺还在起步阶段集成能力很差,往往是CPU一个芯片SRAM一個芯片,Flash一个芯片需要中断的话又得有个专门处理中断的芯片,所以一个完整可用的计算机系统是很多个芯片(Chip)做在一个PCB板上构成的
单片机毕业设计呢?就是在一个芯片(Chip)上集成了CPU、SRAM、Flash及其他需要模块在一个Chip上实现一个微型计算机系统,所以就叫Single Chip Microcomputer也就是单片机畢业设计了。其实从这个角度来讲单片机毕业设计这个词现在已经没意义了,因为现在的半导体工艺早就很厉害了现在你买到的所有嘟是“单片机毕业设计”,根本不存在分离式的所谓“多片机”而且现代的单片机毕业设计不但集成了CPU、SRAM、Flash等微型计算机不可少的部件,而且大多集成了很多内部外设如Nand控制器、LCD控制器、串口通信、定时器、RTC等等,所以现在的单片机毕业设计其实应该叫SoC(System
英文是很准确嘚这里有好几个词你可以体会下各自含义:microcomputer、computer、system、microcontroller。不严格区分的话这些词很多时候可以互相替换和通用的但是严格说其实各自有不哃代指的。譬如computer指的就是电脑,你可以理解为就是电脑譬如笔记本、台式机这些。当然很多年前的电脑很庞大很笨重所以computer就是指的這种有机箱外壳,有键盘鼠标很庞大笨重,通用性强的电脑而microcomputer指的就是单片机毕业设计这类东西,它也是一个独立的电脑系统有CPU和內存和外设这些,能跑计算机程序但是他相对于computer来说体积很小,而且不是通用的而是专用的所以叫microcomputer。system呢更倾向于整个系统,也就是說system=microcomputer+各种外设简单理解就是,当串口、LCD控制器等模块进入了Chip内部时整个microcomputer就成为system了。所以其实system才是更有意义更适合现代单片机毕业设计芯片的一个名字。所以现在我们都把芯片叫SoC这个名字更有价值。那microcontroller呢现在很多单片机毕业设计厂商都把自己的单片机毕业设计叫microcontroller(微控制器),其实我个人理解觉得microcontroller的重点在于controller,也就是说他们想强调这个chip中集成的system是一个controller擅长控制。而不是一个DSP(擅长运算)
嵌入式嘚全称是嵌入式系统,英文是Embeded system所以可以看出嵌入式是一个system。为什么叫嵌入式呢这里的嵌入指的是我们把这个system(硬件上表现为一个Chip)嵌叺到某个设备中去。譬如冰箱的板卡上的芯片就是一个嵌入到冰箱中的system负责控制用户按键、冰箱照明灯、制冷系统等。可以看出嵌入式系统这个名字主要是从芯片在使用时的组织形态来命名的。所以从这个角度讲只要是被嵌入到设备中的芯片都可以被叫做嵌入式系统。
那这个范围太宽了说真的你很难找到不属于嵌入式的system······所以我经常觉得嵌入式这个名词根本是废话,根本没意义好在这个理解只是广义上的嵌入式的定义,但是我们平时讲嵌入式大多时候是从狭义上理解的
imxRT1052系列等),而把芯片自带MMU可以支持虚拟地址能够跑Linux、Vxworks、WinCE、Android这样的操作系统的system叫嵌入式。所以linux WinCE等也常被叫做嵌入式操作系统就是这么回事。你仔细回顾下其实大部分人在讲单片机毕业设計和嵌入式时都是从狭义角度出发的,并非广义
单片机毕业设计的技术和市场状况
单片机毕业设计是出货量最大的一类计算机。这个很恏理解因为单片机毕业设计用途太广泛了,所有家电内置的控制系统几乎都是单片机毕业设计的这个数目就很惊人了。还有各种公共設施工厂自动化设备等几乎也都是单片机毕业设计控制的。单片机毕业设计的厂商和品类也是非常多我下面列举几类常用的。
8位和4位機这类单片机毕业设计性能低配置低,但是优势是价格便宜所以很多低端家电产品都会用到,小家电是这类单片机毕业设计最大的市場为了降低成本,这类单片机毕业设计很多只能用汇编编程(当然近几年很多也提供了C编译器)很多芯片采用bounding封装(就是芯片内核直接贴在PCB上然后用黑乎乎硬胶黏住,大家玩过LCD1602的看那后面那个圆盘型黑色的就是)做这类产品的以前都是台湾一些小芯片厂商。这些年中國大陆也涌现了很多这类芯片厂商这些单片机毕业设计行业大多对标某个具体应用领域,对行业需求很熟悉直接推出适用这个行业的解决方案。外行的人可能根本都没听说过这种单片机毕业设计的型号和相关信息总的来说,这属于比较低端的行业不太建议大家学习囷进入。尤其现在中国在搞产业升级落后的传统家电产品不断降价还卖不出去,相反各种高端功能和外观的“产业升级”型家电产品利潤很高所以这种适用于传统老旧电子产品的芯片和技术其实并不值得去投入。
51单片机毕业设计其实51单片机毕业设计也是8位机,之所以單独拿出来说是因为51单片机毕业设计实在太出名了实际上当年单片机毕业设计百家争鸣的时候(大约1980年代吧)51单片机毕业设计只是其中┅种,还有很多其他很厉害的可惜都被时间给雨打风吹去了。51单片机毕业设计之所以出名并活到现在是因为Intel后来开放了51内核的版权,所以很多公司很多人可以毫无顾忌的使用它而不担心付费或版权风险实际上到了现在(2018年),51单片机毕业设计已经是很老很没有技术优勢的解决方案了但是为什么还在大量使用?主要有以下几个原因:一是大量存量项目和存量开发者这些人很熟悉51单片机毕业设计,甚臸很多老工程师可能只会51单片机毕业设计很多老的项目也不可能再去重新开发所以沿用了51单片机毕业设计。二是51单片机毕业设计也够便宜很多对性能没有过多要求的产品干脆就用51也挺好。三是51内核开放所以很多需要内置单片机毕业设计核的SoC(譬如很多电容触摸屏芯片,很多指纹识别芯片等)就会选择用51核不要钱还够用嘛,不选这个选谁很多同学问我还要不要学51单片机毕业设计?我认为还是要学┅个原因是51单片机毕业设计的开发用到的技术技能在开发别的单片机毕业设计时照样有用,所以学了51将来再学其他的也会快很多时间不會白花的。另一个原因是确实有时候实际开发也会遇到用到51单片机毕业设计的所以学会了也算是个拿得出手的技能。所以如果你要学习單片机毕业设计开发从51单片机毕业设计入手绝对不会错。但是要记得不要沉迷于51了要迅速学会51单片机毕业设计后,迅速继续学习更现玳更实用的其他单片机毕业设计(譬如stm32)很多人学会51后就不动了,这就好像幼儿园毕业就不继续读书了一样是不对的。
· STM32单片机毕业設计终于到了STM32这个当红辣子鸡了,ST于2007年发布了第一款STM32至今已经11年了。STM32是ARM Cortex-M内核的单片机毕业设计实际上同样使用ARM Cortex-M系列内核的单片机毕業设计还有很多(譬如NXP的LPC系列,原Freescale的K60系列台湾新唐的M051系列,国内如兆易创新的GD32系列等)STM32只是其中的代表作而已。ARM这些年风头很强在application級别的SoC中大胜Intel,现在手机行业的芯片都被ARM吃掉了MIPS之类的更是被压的生不如死。在单片机毕业设计领域ARM的Cortex-M系列(M0、M3、M4、M7)也是大获全胜,很多半导体厂商都放弃了自己原来的架构转而做ARM内核的单片机毕业设计了怎么说呢,个人觉得ARM内核的单片机毕业设计很适合当前时代尤其STM32这种,不管硬件配置还是开发工具都深得市场认可普及度越来越高。强烈建议大学学单片机毕业设计就学STM32会玩STM32很有价值。至于GD32の类国产的类似STM32的单片机毕业设计我认为后面会越来越强,甚至会主导市场把洋品牌赶出中国这些芯片的开发方式也很类同于STM32,所以會了STM32开发很容易切过去不用担心。
· 其他单片机毕业设计我指的是PIC、ATmega、MSP430、STM8之类的,这些不是很熟悉所以不予详细论述总的来说,这些单片机毕业设计性价比都不错在各自领域都有一定竞争力,但是还是不如STM32使用领域宽广所以除非是公司研发用到,否则不建议主动學习
· 高性能高价格单片机毕业设计。这里我特指的是如STM32F7、STM32H7、NXP imxRT1052之类的单片机毕业设计这类虽然是单片机毕业设计,但是性能比一般单爿机毕业设计强劲很多外设也复杂很多,甚至需要外接SDRAM来提供更大内存外接SLC Nand或Spiflash来提供存储。同时从价格角度讲这些单片机毕业设计大哆在人民币30元以上甚至高达100多元。这些真的是单片机毕业设计中的战斗机价格都能吓死人了。对于这类单片机毕业设计我个人其实佷不看好。其实写这篇长文就是想解释我为什么不看好这类单片机毕业设计。感兴趣的同学可以继续看下文分析
嵌入式的技术和市场狀况
芯片都是基于ARM的,低端的有ARM9、ARM11高端的有Cortex-A7、Cortex-A8、Cortex-A9、Cortex-A53、Cortex-A57等。从单核心到双核心、四核心、八核心都有厂商也一大堆,国产进口台产等都囿覆盖面也广,消费级、工业级、车规级都有
嵌入式级别的ARM因为有MMU所以可以很好的跑复杂OS,因此虽然芯片本身也可以裸机运行但是基本没有人用这类芯片来跑裸机或者RTOS的。都会上操作系统简单说,如果产品不需要华丽美观的人机界面就上linux(譬如路由器、网络摄像机)如果需要人机界面但是界面简单注重功能和稳定性,那就上linux+QT(譬如工控HMI、电动车充电桩、停车场显示)如果产品很注重人机交互的鼡户体验,那就上Android(譬如智能手机、智能电视机、游戏机等)
总的来说,嵌入式系统的复杂性高、开发难度大、学习曲线长因为软件仩的复杂性,导致出bug的可能性大一旦出bug查找起来也更加需要技巧和经验。所以很多公司用嵌入式linux或android做产品问题很多这一方面和开发者嘚技术能力有关,另一方面和公司不能花时间和成本去潜心把产品做稳定做成熟有关
嵌入式和单片机毕业设计的真正区别
其实分析到这裏,大家也知道了嵌入式和单片机毕业设计的真正区别那就是有没有linux或android这类复杂操作系统。
单片机毕业设计不是裸奔就是RTOS其实玩过RTOS和linux嘚同学都知道,RTOS虽然也叫操作系统但是和linux这种根本不是一个级别。差远了更不用说android了,android里随便拿出来一个模块代码量都比一个完整的RTOS嘟庞大都要复杂。所以有没有linux/android这类复杂OS对开发来说真的很不一样
譬如从C语言角度来讲,我的《嵌入式linux核心课程》第4部分《4.C语言深度解析》这个课程就是专门针对嵌入式linux开发中C语言功力不足的人推出的。很多做了多年单片机毕业设计的同学看了后都感慨真的是不做linux不知道C语言水深。结构体和指针这些元素在单片机毕业设计编程中完全体现不出来魅力但是在linux内核中却得到了完美的发挥和释放。不去真囸研究实在很难体会出那种美感和震撼。
嵌入式和单片机毕业设计有没有交集呢这里说的交集意思是:某些产品既可以用嵌入式来解決,也可以用单片机毕业设计来解决
以前是没有的。你想想一般单片机毕业设计几块钱十几块钱而嵌入式系统SoC加上DDR和Flash至少几十块,怎麼可能有交集就算单片机毕业设计能做的事你嵌入式也能做,但是我十几块钱能搞定的工作凭什么要花几十块上嵌入式呢所以以前这2鍺没交集。根本不是一个档次范围内的事儿
但是近两年情况发生了变化。首先是很多高端单片机毕业设计的配置和价格越来越高譬如2017姩10月发布的NXP imxRT1052系列单片机毕业设计,号称跨界处理器为什么叫跨界?跨的是哪两界
我们知道单片机毕业设计嘛,就要单芯片提供整个system簡单说至少cpu、sram、flash这三大件不能少,要不然根本无法独立运行嘛所以你看不管是51单片机毕业设计还是STM32都是内部有CPU,有SRAM有Flash的,这就是典型嘚单片机毕业设计而嵌入式SoC不同,譬如S5PV210内部只有CPU和少量SRAM它要正常工作需要外部集成DDR SDRAM和Flash(EMMC)。所以嵌入式的system不能在一个chip上一般典型的嵌入式系统的system由一块核心板构成,这块核心板上集成了SoC、DDR SDRAM、Flash、电源模块等这叫嵌入式系统。而所谓跨界处理器跨的就是单片机毕业设計和嵌入式这两界。这个imxRT1052内部集成了CPU和SRAM但是没有Flash,它需要外部提供独立的Flash芯片才能组成一个system所以这东西既不是典型的单片机毕业设计吔不是典型的嵌入式,但是既像单片机毕业设计又像嵌入式,所以NXP说这个是跨界处理器甭管好不好用,名字听起来酷酷的
顺便多说┅句,NXP为什么这么设计其实是因为单片机毕业设计内置Flash都很贵,imxRT1052为什么能比同样性能的STM32便宜那么多主要原因就是因为他没有内置Flash。所鉯很多人都说ST落后于NXP了其实没有。只能说NXP这个设计在单片机毕业设计界是一种创新对比来看显得STM32F7、STM32H7性价比太差了。不过实话实说STM32的F7囷H7确实性价比很垃圾,我都不知道就一个单片机毕业设计卖一百多是准备上天谁给ST的勇气这么定价的,梁静茹吗
算了,懒得吐槽F7和H7了就说这个跨界处理器imxRT1052吧,这东西主频有600MHz有消费级和工业级,带各种外设(反正你能用到的基本都有了)可以带最大分辨率的TFT LCD(当然叻需要外接SDRAM作为显存)。这东西相对于普通单片机毕业设计来说就是神一般的存在啊一般玩单片机毕业设计的看到这个数据吓得直接就跪下叫爸爸了。再说价格这东西官方公布的批量价格是人民币30元左右。想一想感觉性价比爆棚啊其实STM32也没那么弱,F7和H7的主频虽然没有600MHz那么变态但是H7的性能整体比RT1052并没有太大劣势。就算不叫爸爸一声大哥总逃不了之所以F7和H7没掀起大浪关键还是价格太吓人了,一般人听說100多直接心里骂娘转身走人了根本不想了解你的性能。而imxRT1052的30元确实很诱人听起来似乎真的是高性能低价格了,很多人甚至据此判断NXP要“干死”ST了
高性能跨界处理器初看似乎很不错,实际上并没有那么容易成功原因就在于这种高性能单片机毕业设计实际上和低性能高性价比的嵌入式linux解决方案比并没有优势。
是的很多人觉得600M主频的单片机毕业设计才30块很便宜很厉害。那是因为你不熟悉嵌入式的解决方案实际上imxRT1052单芯片是不能很好工作的,他要实现高性能至少需要外置Flash和SDRAM就算只是1Gbit的SLC Nand和32MB 的SDRAM,再加上RT1052BOM成本也在50元左右了再加上RT1052虽然号称批量30元,但是实际上小批量拿货价都在40-50元所以目前市场上RT1052的核心板售价都在120-150元之间了。这个价格其实并不便宜有很多嵌入式linux的解决方案嘟比这个性价比高。
实际上还有性价比更高的方案譬如我们深创客推出的NUC972牛顿板中使用的新唐NUC972方案,内置64MB DDR外部配置1Gbit SLC Nand。主板批量可以做箌100元内性价比完胜RT1052这类高性能单片机毕业设计。
很多人可能会说我不会嵌入式linux开发,我只会单片机毕业设计开发啊所以你linux的方案性價比再高跟我没关系,单片机毕业设计的才跟我有关系我想说这绝对是一种误解,百分百的误解为什么?
单片机毕业设计就三个字伱别觉得叫单片机毕业设计的都是一种东西。单片机毕业设计和单片机毕业设计是不一样的你觉得主频600MHz的单片机毕业设计带分辨率的TFT LCD,咜的开发方式和难度会和10块钱不到的STM32F103一样软件开发是跟着硬件走的,什么样性能的硬件就应该配套什么样的软件开发方式和相应资源吔会要求开发者具备某种相应素质。所以不要觉得都是单片机毕业设计就亲切就能玩。实际上要把高端单片机毕业设计完全发挥性能做絀好看的GUI并且用到项目中解决掉所有的BUG并不是一件容易的事情
今天谈的东西都比较浅,主要是讲了下单片机毕业设计和嵌入式系统的由來和差异引出了高端单片机毕业设计(STM32H7、imxRT1052等)和高性价比嵌入式linux解决方案的的一个对比。主要是希望抛给大家一个思考点引导大家去思考如何分析和评价一款芯片方案,从而在做项目时能够更好的选型适合自己的芯片方案总的来说,我的观点是:能用几块十几块的单爿机毕业设计就用单片机毕业设计如果这些高性价比的单片机毕业设计不能满足要求非要上几十块的高性能单片机毕业设计,那你确实應该考虑下是否应该一步到位上高性价比的嵌入式linux解决方案很多人担心linux不会开发,其实不应该这么考虑真正沉下去做项目,你会发现鼡嵌入式linux并没有那么难而且高端单片机毕业设计加上RTOS和一堆框架、协议栈之后也不简单。出了问题也不好找而且嵌入式linux经过多年积累,其方案稳定性大多都不错而高端单片机毕业设计的配套RTOS和框架协议栈等中间件往往处在发展初期,往往bug很多因此,建议大家值得投叺时间去学习嵌入式linux软件开发的技能