STM32单片机的入门教程总结
优秀的处理器配合好的开发工具和工具链成就了单片机的辉煌,这是单片机开发者辛勤劳动的结果。也正因为此,ARM的工具链工程师和CPU工程师强强联手,日日夜夜不停耕耘为ARM7TDMI设计出了精练、优化和到位的内部结构,终于成就了ARM7TDMI的风光无限的辉煌。新的ARM Cortex-MB处理器在破茧而出之后,就处处闪耀着ARM体系结构激动人心的新突破。它是基于最新最好的32位ARMv7架构,支持高度成功的Thumb-2指令集,并带来了很多前卫崭新的特性。在它优秀,强大的同时,编程模型也更清爽,因而无论你是新手还是骨灰级玩家都会对这样秀外慧中的小尤物爱不释手。根据ARM的统计,2010年全部Cortex-M MCU出货量为1.44亿片,2008年~2011年第一季度,STM32累计出货量占Cortex-M MCU出货量的45%。也就是说,两个Cortex-M微控制器中有一个就来自ST。很多市场分析机构也对ARM的强劲增长表示认可。2007年在32/64位 MCU及MPU架构中,ARM所占市场份额为13.6%,而2010年已经占了23.5%,击败了Power Architecture,成为市场占有率最多的架构。Cortex-n3内核是ARM公司整个Cortex内核系列中的微控制器系列(M)内核,另外两个系列分别是应用处理器系列(A)与实时控制处理系列(R),这三个系列分别简称为A、R、M系列。它们分别有各自不同的应用场合。Cortex-MB内核是为满足存储器和处理器的尺寸对产品成本影响很大的广泛市场和应用领域的低成本需求而专门开发设计的,主要应用于低成本、小管脚数和低功耗的场合,并且具有极高的运算能力和极强的中断响应能力。Cortex-M3处理器采用纯Thumb-2指令的执行方式,使得这个具有32位高性能的ARM内核能够实现8位和16位的代码存储密度。核心门数只有3K,在包含了必要的外设之后的门数也只有60K,使得封装更为小型,成本更加低廉。Cortex-n3采用了ARMV7哈佛架构,具有带分支预测的3级流水线,中断延退最大只有12个时钟周期,在末尾连锁的时候只需要6个时钟周期。同时具有1.25DMIPS/MHZ的性能和0.19MW/MHZ的功耗。社会对基于ARM的嵌入式系统开发人员的高需求及给予的高回报,催生了很多的培训机构,这也说明嵌入式系统的门槛较高。其主要原因有以下几点:1. ARM本身复杂的体系结构和编程模型,使得我们必须了解详细的汇编指令,熟悉ARM与Thumb状态的合理切换,才能理解Bootloader并对操作系统进行移植。而理解Bootloader本身就比较困难,因此对于初学者来说,Bootloader的编写与操作系统的移植成了入门的第一道难以逾越的门槛。2. ARM芯片、开发板及仿真器的高成本,直接影响了嵌入式开发的普及,使得这方面人才增长缓慢。3. 高校及社会上高水平嵌入式开发人员的短缺,现实问题使得我们的大学生和公司职工在入门的道路上困难重重,很多人也因此放弃。4. 培训机构的高费用虽然有高水平的老师指导,但费用是一道关口,进入的人只能在短短几天内匆匆了解开发过程,消除一些畏惧心理,但修行还是得靠自己。5. 好的开发环境需要资金支持,也影响了入门的进度。基于Cortex-M3内核的ARM处理器的出现,在优秀的Keil开发工具的支持下,可以自动生成启动代码,省去了复杂的Bootloader编写。Thumb-2指令集的使用使得开发人员不用再考虑ARM状态与Thumb状态的切换,节省了执行时间和指令空间,大大减轻了软件开发的管理工作。处理器与内存尺寸的减少,降低了成本,使得芯片及开发板的价格得以在很大程度上降低。Cortex-M3内核通过将中断控制器、MPU及各种调试组件等基础设施的地址固定,极大地方便了程序的移植。源代码是公开的库函数,使得我们可以摒弃晦涩难懂的汇编语言,在不需要了解底层寄存器操作细节的情况下,用C语言完成所需功能。这些特点使我们学习ARM处理器的门槛降低,同时建议大家尽量使用固件库,而不是避开固件库自己写代码。在实际项目中,代码成百上千,不可能都自己写,调用固件库中的函数才是可行的方案。当然,深入理解寄存器操作也是必要的,高效编程必须在这方面努力。